存在环的单链表寻找环的入口点

 看了这么多文章,觉得这个作者写的寻找环入口是最好理解的,对不起作者,忘记出处的网址了,当时粘到WORD文档里的,如果再次看到了,一定标明出处!!

 问题2:若存在环,如何找到环的入口点(即上图中的结点E)?
      解答:如图中所示,设链起点到环入口点间的距离为x,环入口点到问题1中fast与low重合点的距离为y,又设在fast与low重合时fast已绕环n周(n>0),且此时low移动总长度为s,则fast移动总长度为2s,环的长度为r。则
       s + nr = 2s,n>0      ①
       s = x + y               ②
      由①式得  s = nr                
      代入②式得
      nr = x + y
      x = nr - y                ③
      现让一指针p1从链表起点处开始遍历,指针p2从encounter处开始遍历,且p1和p2移动步长均为1。则当p1移动x步即到达环的入口点,由③式可知,此时p2也已移动x步即nr - y步。由于p2是从encounter处开始移动,故p2移动nr步是移回到了encounter处,再退y步则是到了环的入口点。也即,当p1移动x步第一次到达环的入口点时,p2也恰好到达了该入口点。


如何求环的长度,fast和low第一次相遇后,再继续,第二次相遇时,fast正好多走了一个环的长度,即可求~~无奈当时面试的时候,硬是没有想出来啊!!!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值