判断链表是否存在环,如果存在找到环的入口位置。

一、 有环链表

什么是有环链表,只需要一张图就能说明什么是有环链表,如下:

二、如何实现有环链表

这篇文章,有详细的实现。如何创建一个有环链表

三、判断是否存在环

3.1 先解决第一个问题,如何判断链表中存在环???

采用一个快慢指针fastslowfast每次移动两位,slow 每次移动一位。如果最后他们可以相遇,说明存在环。

3.2 两颗指针一定会相遇吗?

会, 因为每一次移动他们之间的差距只会增加 1 位,快慢指针进入环以后,每一次快指针都会比慢指针多移动一步,因此快指针必定会追上慢指针。

3.3 实现

根据上面的思路完成代码:

ini 复制代码
function resolve(head) {
	// 定义快慢指针
	let fast = head;
	let slow = head;
	// 不用判断 p ,因为p 要走的路,q 都走过了,q.一定不为null
	while (fast !== null && fast.next !== null) {
		slow = slow.next; // `slow` 每次移动一位
		fast = fast.next.next; //`fast`每次移动两位
		if (fast === slow) {
			return true; // 相遇说明存在环
		}
	}
}

console.log(resolve(list.head));

四、找到环的入口

4.1 如何找到环的入口呢? 先分析一波

  1. slow 走的距离:a + b
  2. fast 走的距离 a + n(b+c) + b

4.2 slow一定是 a+b吗?slow一定不可能在相遇之前走完一个环吗?

是的,slow 不可能走完一个环。我们假设slow 能走完一个环,那么在这段时间内fast 就必定能走完两个环,在slow 走完之前,他们一定已经相遇了。(其实可以,但是需要从同一个位置出发,也就是相遇点和出发点都在环的入口处,此时slow刚好有机会走完一个环,但是在这之前已经相遇了。没有讨论的意义)

4.3 推导

根据以上信息,可以得到一个等式: 2(a + b) = a + n(b + c) + b

化简等式:

a= n(b+c) - b

= n(b+c) - b - c + c

=n(b+c) - (b+c) + c

= (n-1)(b+c) + c

也就是说:a = (n-1)(b+c) + c

这意味着:

  1. b+c 不就是环的长度吗,而 c 就是相遇点到环入口的距离。
  2. 如果我们现在开始定义两颗指针,p1从头指针开始 ,p2 从相遇点开始,每次两个指针都移动一位。
  3. 经过(n-1)(b+c) + c 次移动后,p1 和 p2 一定会在口处相遇
  4. 只需要定义一个计数器,记录相遇之前移动了多少次,就是 a 的大小。
  5. 相遇的之前,p2 移动了n 圈,外加一段 c.

4.4 实现:

js 复制代码
function resolve(head) {
	// 定义快慢指针
	let fast = head;
	let slow = head;
	// 不用判断 p ,因为p 要走的路,q 都走过了,q.一定不为null
	while (fast !== null && fast.next !== null) {
		slow = slow.next; // 慢指针每次移动一位
		fast = fast.next.next; // 快指针每次移动两位
		if (fast === slow) {
			let p1 = head;
			let p2 = fast;
			let count = 0; // 记录移动的次数
			while (p1 !== p2) {
				p1 = p1.next; // p1,p2每次后移动一位
				p2 = p2.next;
				count += 1;
				if (p1 === p2) return count; // 相遇结束循环
			}
		}
	}
	return -1; // 代表没有环
}

console.log(resolve(list.head));

完美,撒花~~~~~

相关推荐
吃好睡好便好7 分钟前
在Matlab中绘制抛物三维曲面图
开发语言·人工智能·学习·算法·matlab·信息可视化
伯远医学15 分钟前
Nat. Methods | 邻近标记技术:活细胞中捕捉分子互作的新利器
java·开发语言·前端·javascript·人工智能·算法·eclipse
刘永鑫Adam34 分钟前
Nature Microbiology | 基于TRACS算法的跨多界宏基因组数据菌株水平溯源推演
算法
小O的算法实验室37 分钟前
2026年SEVC,面向无人机辅助边缘计算的自适应群体智能算法,深度解析+性能实测
算法·边缘计算·智能算法·智能算法改进
高锰酸钾_43 分钟前
计算机网络-网络层-路由算法与路由协议
计算机网络·算法·智能路由器
智者知已应修善业1 小时前
51单片机4按键控制共阳LED霓虹灯切换1整体闪烁2流水下3流水上4间隔闪烁】2023-10-27
c++·经验分享·笔记·算法·51单片机
XW-ABAP1 小时前
SAP ABAP 实现类似百度谷歌搜索引擎基础算法之一的,编辑距离算法
算法
嵌入式小能手1 小时前
飞凌嵌入式ElfBoard-进程间的通信之信号处理sigaction
linux·算法·信号处理
re林檎1 小时前
算法札记——5.14
算法
研究点啥好呢1 小时前
DJI 机器人视觉算法工程师 面试题精选:10道高频考题+答案解析(背诵版)
算法·面试·机器人·dji