链表题解——环形链表 II【LeetCode】

142. 环形链表 II

快慢指针法

  • 核心思想

    1. 快慢指针
      • 使用快慢指针(fastslow)遍历链表。
      • 快指针每次移动两步,慢指针每次移动一步。
      • 如果链表存在环,快指针最终会追上慢指针(相遇)。
    2. 找到环的入口
      • 当快慢指针相遇时,初始化一个新指针 ptr,指向链表头节点。
      • 同时移动 ptrslow,每次移动一步,直到它们相遇。
      • 相遇的节点就是环的入口节点。

上面思路和图解来自灵茶山艾府

  • 时间复杂度

    • 最坏情况下需要遍历整个链表,时间复杂度为 O(n),其中 n 是链表的节点数。
  • 空间复杂度

    • 只使用了常数级别的额外空间,空间复杂度为 O(1)
python 复制代码
class Solution:
    def detectCycle(self, head):
    slow = fast = head  # 初始化慢指针和快指针,都指向链表头节点
    while fast is not None:  # 当快指针不为空时
        slow = slow.next  # 慢指针每次移动一步
        if fast.next is None:  # 如果快指针的下一个节点为空
            return None  # 说明链表没有环,返回 None
        fast = fast.next.next  # 快指针每次移动两步
        if fast == slow:  # 如果快慢指针相遇
            ptr = head  # 初始化一个新指针,指向链表头节点
            while ptr != slow:  # 当新指针和慢指针不相遇时
                ptr = ptr.next  # 新指针每次移动一步
                slow = slow.next  # 慢指针每次移动一步
            return ptr  # 返回新指针指向的节点(即环的入口节点)
    return None  # 遍历结束,没有发现环,返回 None
相关推荐
数智工坊17 小时前
【数据结构-队列】3.2 队列的顺序-链式实现-双端队列
数据结构
elseif12317 小时前
【C++】并查集&家谱树
开发语言·数据结构·c++·算法·图论
徐小夕@趣谈前端17 小时前
Web文档的“Office时刻“:jitword共建版2.0发布!让浏览器变成本地生产力
前端·数据结构·vue.js·算法·开源·编辑器·es6
不穿格子的程序员18 小时前
从零开始写算法——普通数组篇:缺失的第一个正数
算法·leetcode·哈希算法
Nebula_g18 小时前
线程进阶: 无人机自动防空平台开发教程(更新)
java·开发语言·数据结构·学习·算法·无人机
xuxie9919 小时前
day 23 树
数据结构
VT.馒头20 小时前
【力扣】2722. 根据 ID 合并两个数组
javascript·算法·leetcode·职场和发展·typescript
EnglishJun20 小时前
数据结构的学习(四)---栈和队列
数据结构·学习
执着25920 小时前
力扣hot100 - 108、将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
数智工坊20 小时前
【数据结构-特殊矩阵】3.5 特殊矩阵-压缩存储
数据结构·线性代数·矩阵