链表题解——环形链表 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
相关推荐
荒诞硬汉7 分钟前
数组常见算法
java·数据结构·算法
2301_800256111 小时前
B+树:数据库的基石 R树:空间数据的索引专家 四叉树:空间划分的网格大师
数据结构·数据库·b树·机器学习·postgresql·r-tree
独自破碎E1 小时前
【队列】按之字形顺序打印二叉树
leetcode
码农幻想梦1 小时前
第九章 高级数据结构
数据结构
AlenTech1 小时前
206. 反转链表 - 力扣(LeetCode)
数据结构·leetcode·链表
踩坑记录1 小时前
leetcode hot100 438. 找到字符串中所有字母异位词 滑动窗口 medium
leetcode·职场和发展
大厂技术总监下海1 小时前
用户行为分析怎么做?ClickHouse + 嵌套数据结构,轻松处理复杂事件
大数据·数据结构·数据库
YuTaoShao1 小时前
【LeetCode 每日一题】1458. 两个子序列的最大点积——(解法三)状态压缩
算法·leetcode·职场和发展
AI科技星2 小时前
光速飞行器动力学方程的第一性原理推导、验证与范式革命
数据结构·人工智能·线性代数·算法·机器学习·概率论