快慢指针和找环入口

用快慢指针的方式应该经过面试准备的人都知道了。

那么怎么找环的入口呢。

假设从链表开始的位置到环入口的距离为p,慢指针在环内走了的距离为c,假设慢指针一共走了n步,快指针一共做了2n步。

那么,有p+c=n

显然,从p+c这一点开始,慢指针再走n步,必然还会回到这个点。为啥?【因为经过了2n步,快指针到达了这一点,所以慢指针如果再走n步,也会到达这一点】

如果让快指针从链表头开始走n步,也会到达p+c这个位置,二者相遇的第一个地方,肯定是环入口。

看图

图里,AB=p,BD=c,由于慢指针走了n步,快指针走了2n步,所以慢指针再走n步还是到达D点。

【DB=c只是说,慢指针在环内走了c这么远,不一定是不到一圈,也可能慢指针在环内走了几圈之后才到达D点,此时我们假定BD长度是这路径的总长为c

所以,得到如下解决办法:

在快慢指针相遇之后,让快指针重新指向链表头,慢指针还在p+c位置,然后二者同时走p步,每次走一步。走完之后二者相遇的位置就是环入口了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值
>