LeetCode Hot100(23/100)——142. 环形链表 II

文章目录

一、题目描述

给定一个链表,返回链表 开始入环的第一个节点

如果链表中没有环,则返回 null

注意:不允许修改链表结构。


二、示意图与问题本质

假设链表结构如下:

在这里,链表的尾节点 -4 指向了 2 节点,从而形成了一个环。题目要求返回环开始的节点,即节点值为 2 的节点。


三、思维导图

环形链表 II
定义与目标
查找入环节点
无环返回 null
解法路线
快慢指针(Floyd 判圈)
哈希集合法
分析指标
时间复杂度
空间复杂度
代码实现


四、解法一:哈希集合法(直观易懂)

思路

我们可以用一个 Set 记录访问过的节点。

每次遍历时,检查当前节点是否已存在于集合中:

  • 若存在,说明当前节点即为 入环节点
  • 若不存在,则继续向下走并添加到集合中。

流程图





当前节点 head
节点是否为空?
返回 null
Set 中是否包含该节点?
返回当前节点
将当前节点加入 Set
head = head.next

时间与空间复杂度

  • 时间复杂度:O(n)
  • 空间复杂度:O(n)

Java 代码

java 复制代码
public class Solution {
    public ListNode detectCycle(ListNode head) {
        Set<ListNode> visited = new HashSet<>();
        ListNode curr = head;
        while (curr != null) {
            if (visited.contains(curr)) {
                return curr; // 找到入环点
            }
            visited.add(curr);
            curr = curr.next;
        }
        return null; // 无环
    }
}

优缺点

优点 缺点
思路直观,容易实现 需要额外空间存储访问节点

五、解法二:快慢指针法(Floyd 判圈算法)

思路

使用两个指针:

  • 快指针 fast 每次走两步。
  • 慢指针 slow 每次走一步。
  1. 如果存在环,fastslow 最终会在环中相遇。
  2. 相遇后,将 fast 指针置回 head,两个指针每次都走一步。
  3. 当它们再次相遇时,相遇点即为 入环节点

原理推导

设:

  • 链表从头到入环点的长度为 a
  • 入环点到第一次相遇点的长度为 b
  • 环的长度为 r

第一次相遇时:

复制代码
slow 走了 a + b
fast 走了 a + b + k*r  (k为圈数)

因为 fast 的速度是 slow 的两倍:

复制代码
2(a + b) = a + b + k*r
=> a = k*r - b

这意味着:

从起点走 a 步,与从相遇点走 r - b 步(即再次绕环)会在入环节点相遇。

时序图

快指针 慢指针 链表头 快指针 慢指针 链表头 loop 移动指针直到相遇或结束 loop 同步前进直到再次相遇 初始化 初始化 前进 1 步 前进 2 步 相遇于环中 重置至链表头 前进一步 前进一步 再次相遇 ->> 入环节点

时间与空间复杂度

  • 时间复杂度:O(n)
  • 空间复杂度:O(1)

Java 代码

java 复制代码
public class Solution {
    public ListNode detectCycle(ListNode head) {
        if (head == null) return null;
        ListNode slow = head, fast = head;

        // 第一次相遇
        while (fast != null && fast.next != null) {
            slow = slow.next;
            fast = fast.next.next;
            if (slow == fast) {
                // 第二阶段
                fast = head;
                while (fast != slow) {
                    fast = fast.next;
                    slow = slow.next;
                }
                return fast; // 入环节点
            }
        }
        return null; // 无环
    }
}

优缺点

优点 缺点
不需要额外空间 理解原理相对抽象,需要数学推导

六、总结

解法 思路 时间复杂度 空间复杂度 适用场景
哈希集合法 记录访问过的节点 O(n) O(n) 快速验证思路
快慢指针法 数学+双指针 O(n) O(1) 实际应用最优方案
相关推荐
MicroTech202527 分钟前
量子隐形传态路线的瓶颈与突破,微算法科技(MLGO)以技术创新助力量子通信长距离组网
科技·算法·量子计算
洛水水27 分钟前
【力扣100题】89.下一个排列
数据结构·算法·leetcode
洛水水28 分钟前
【力扣100题】90.寻找重复数
算法·leetcode·职场和发展
鱼子星_33 分钟前
【数据结构】排序的拓展——快速排序的生态多样性与归并排序沾染文件操作
c语言·数据结构·算法
alphaTao33 分钟前
LeetCode 每日一题 2026/6/8-2026/6/14
算法·leetcode
KaMeidebaby38 分钟前
卡梅德生物技术快报|噬菌体展示文库构建全流程解析 | 大豆球蛋白纳米抗体筛选实践
人工智能·python·tcp/ip·算法·机器学习
kkkAloha44 分钟前
链表解题总结
数据结构·链表
CC数学建模1 小时前
2026年第十六届APMCM 亚太地区大学生数学建模竞赛(中文赛项)赛题B题:高性能芯片热管理系统的优化问题完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
爱睡懒觉的焦糖玛奇朵1 小时前
【视觉检测之人员奔跑检测算法开发思路】
人工智能·python·深度学习·算法·yolo·视觉检测
05候补工程师1 小时前
【408考研复习】数据结构核心笔记:字符串模式匹配与内部排序算法全解析
数据结构·经验分享·笔记·考研·算法·排序算法