<
查看: 1564|回复: 1
收起左侧

[Leetcode] Linked List Cycle II 的清晰易理解的思路 希望是正确的 欢迎大家指正

|只看干货
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   100% (4)
 
 
0% (0)    👎

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
这里假设 cycle入口前长度为m cycle一整圈长度为n  fast与slow 在距离cycle入口 x长度的位置相遇 此时:
slow的路程:m + x
fast的路程:2m + 2x
两者距离cycle入口的距离分别为 x, 2x + m - n.假设fast多走一圈(此处假设n > m, 若n<m, 可以给n加一个系数k,k代表fast多走的圈数)此处考虑最简单的情况便于分析。
x ?= 2x +m - n --> n ?= x + m
x = n - m结论成立 此点和初始起点距离cycle入口皆为 m 距离 此时把fast放回起点 速度降为一, slow继续 , 下次相遇时的位置即为cycle入口节点位置.

上一篇:udacity的技术面课程 --- 有人上过吗?质量如何?
下一篇:一道动态规划题,没思路。
staycrazy 2016-4-29 07:07:25 | 显示全部楼层
本楼: 👍   0% (0)
 
 
0% (0)   👎
全局: 👍   96% (204)
 
 
3% (7)    👎
建议你读一下quora上的这个答案:
https://www.quora.com/How-does-Floyds-cycle-finding-algorithm-work/answer/Albert-Chen-31

这是我见过的最直观的解释。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表