关于有环链表的求入环节点的思路

环形链表例图

如图所示,首先我们必须先确定这个链表是否包含一个环,我们可以使用两个指针,A指针步长为1, B指针步长为2。同时从头节点处出发,如果A指针与B指针重合了,那么我们可以说这个链表中包含环,如果B指针最后为null,那么该链表不包含环。

既然链表包含环,那怎么求这个环的入口节点?
其实,这个问题可以转化为数学问题来解释更直观一些。

假设我们有两个指针A,B。A指针速度为v1, B指针速度为v2,v2 = n v1,设链表中环长为L,A在t时间内的路程为S1,B在t时间内的路程为S2。我们知道B比A快,所以B会先进入环,并且B在A走完一个环之前就会与之相遇!!(这个地方要理解,假设A指针和B指针同时在A点入环,那么A指针走完一个环的时候,B指针走完了n 个环,并且会在A点相遇,如果B指针先入环,那么A在走完一个环的时候,肯定会被B追上!)我们设这个相遇点为Z。

好了,介绍了以上的必要的点。接下来就是这个求法的思路:
因为:S1 = v1 * t S2 = v2 * t S2 = nL + S1
若在Z点相遇,

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值