如何判断单链表是否有环、环的入口、环的长度和总长

问题描述1.如何判断单链表是否有环? 2.如果有环,求出环的入口 3.求环长 4.求总长注意这里长度:节点的数量 链表定义参考:http://blog.csdn.net/dawn_after_dark/article/details/73610674探讨要想判断有环,我们可以联系实际生活中的例子,很容易就想到操场上跑圈,因为是环形,所以快的肯定会追上慢的,所以我们可以应用到链表上,用一个快指
摘要由CSDN通过智能技术生成

问题描述

1.如何判断单链表是否有环?
2.如果有环,求出环的入口
3.求环长
4.求总长

注意这里长度:节点的数量
链表定义参考:http://blog.csdn.net/dawn_after_dark/article/details/73610674

探讨

要想判断有环,我们可以联系实际生活中的例子,很容易就想到操场上跑圈,因为是环形,所以快的肯定会追上慢的,所以我们可以应用到链表上,用一个快指针和一个慢指针,但是细想一下发现,我们在跑操的时候相遇时坐标位置不一定是整数啊(这里相比链表节点而言的),而链表是一个节点连接起来,我们怎么做,能让他们在节点上相遇呢,这里就要为2个指针找到合适的速度,使之能够恰巧在某一结点上相遇。

原理:如果快的指针走到NULL,说明无环;而fast==slow相遇,则证明肯定存在环。

公式推导

为什么存在环的情况下,两个指针会相遇呢?以下推到n都是指 环长!

问题一

这里写图片描述
1.假定2个指针同一个起点
我们让两个指针全部指向头节点,然后给slow指针的速度为一步,而fast指针的速度为M步,则在第i次迭代的时候,slow指针走到i mod n,而fast指向Mi mod n,要想slow和fast相遇,则i mod n=Mi mod n,(M-1)i mod n,则我们可以令M=2(最小的可以取得值),i mod n = 0,则 i=n时,相遇,所以我们可以给fast 2倍的速度,这样它们会在 最后一个节点相遇。
2.假定不在同一个起点,并且fast提前K位置
其实这个类似链表中含有个小环的情况,即不是所有点在环中的情况,这样当slow即将进入环状的时候,fast已经在环中k mod n位置了,所以问题转化为假定不在同一个起点,并且fast提前K位置,是否会在一点相遇?

  • 11
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 10
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值