如何判断单链表是否存在环

给定一个单链表,只给出头指针h:

  1. 如何判断是否存在环?
  2. 如何知道环的长度?
  3. 如何找出环的连接点在哪里?
  4. 带环链表的长度是多少?

下面我们来依次分析上面的问题。

如何判断是否存在环

这里我们考虑使用快慢指针的方式。快指针 fast 每次移动2个节点,慢指针 slow 每次移动一个节点。如果没有环,则 fast 指针将碰到 null,如果有环,则 fast 会在若干次移动后追上 slow。

为什么呢?假定单链表的长度为n,并且该单链表是环状的,那么第i次迭代时,p指向元素i mod n,q指向2i mod n。因此当i≡2i(mod n)时,p与q相遇。而i≡2i(mod n) => (2i - i) mod n = 0 => i mod n = 0 => 当i=n时,p与q相遇。

那么当p与q起点不同呢?假定第i次迭代时p指向元素i mod n,q指向k+2i mod n,其中0<k<n。那么i≡(2i+k)(mod n) => (i+k) mod n = 0 => 当i=n-k时,p与q相遇。

如何知道环的长度

由上一部分的分析我们可以知道,当起点相同时,i 等于 n 时两者会再次相遇,所以从相遇点开始,快慢指针再次相遇时经过的步骤数为环的长度。

如何找出环的连接点在哪里

假设第一个在环里的节点为节点 k,那么由上面的分析知道,满节点到达 k 节点时,快节点已经领先了慢节点 k mod n,所以相遇点在 i = n - k 处。这样,一个节点从相遇点开始,一个节点从头结点开始,以相同的速度行走,最终,经过k步,一个刚好从到达n,即回到了起点处,另外一个到达了 k,即起点处。

带环链表的长度是多少

已经知道了环的长度和环的入口,可以计算出链表的长度。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • include<iostream> using namespace std; //单链表 typedef stru...
    jmychou阅读 460评论 0 0
  • 树的概述 树是一种非常常用的数据结构,树与前面介绍的线性表,栈,队列等线性结构不同,树是一种非线性结构 1.树的定...
    Jack921阅读 4,509评论 1 31
  • //leetcode中还有花样链表题,这里几个例子,冰山一角 求单链表中结点的个数----时间复杂度O(n)这是最...
    暗黑破坏球嘿哈阅读 1,557评论 0 6
  • 9.3.3 快速排序   快速排序将原数组划分为两个子数组,第一个子数组中元素小于等于某个边界值,第二个子数组中的...
    RichardJieChen阅读 1,877评论 0 3
  • 当我看到那些冰毒的时候 我就会想起我的女儿 我在寄人篱下的家里被剥夺抚养权 只有另一个女人会带她来看我 当我去抢钱...
    一首诗和小H阅读 197评论 2 3