leetcode hot100 环形链表 easy 快慢指针


解题思路:快慢指针

想象两个人在圆形操场上跑步:

慢指针(Slow): 每次走 1 步。

快指针(Fast): 每次走 2 步。

结论:

如果链表没有环,快指针会率先到达终点(指向 NULL)。

如果链表有环,快指针最终一定会从后面"追上"慢指针(两者指向同一个节点)。

时间复杂度O(N)O(N)O(N)

空间复杂度O(1)O(1)O(1)

python 复制代码
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def hasCycle(self, head: Optional[ListNode]) -> bool:

        # 边界处理:如果链表为空或只有一个节点,不可能有环
        if not head or not head.next:
            return False

        fast =  head
        slow = head

        # 如果没有环,快指针会率先到达终点(指向 NULL)
        while fast and fast.next:
            slow = slow.next
            fast = fast.next.next
            
            if slow == fast:
                return True

        return False
        

"同一个地址" vs "相同的值"

  • slow == fast (判断节点对象/地址): 检查这两个指针是否指向内存中同一个物理位置。如果是同一个位置,说明快指针真的"绕回来"追上慢指针了。
  • slow.val == fast.val (判断数值): 检查这两个节点里存的数字是否一样。

链表长度为奇数(如 3 个节点)

  • fast 移动到 [3](最后一个节点)。此时:fast.next 是 NULL。循环结束

链表长度为偶数(如 4 个节点)

  • fast 移动到 NULL(冲出了边界)
相关推荐
TracyCoder1231 小时前
LeetCode Hot100(34/100)——98. 验证二叉搜索树
算法·leetcode
We་ct3 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
努力学算法的蒟蒻6 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_841495646 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
2401_841495646 小时前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
我是咸鱼不闲呀6 小时前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
铉铉这波能秀7 小时前
LeetCode Hot100数据结构背景知识之列表(List)Python2026新版
数据结构·leetcode·list
仟濹8 小时前
算法打卡 day1 (2026-02-06 周四) | 算法: DFS | 1_卡码网98 可达路径 | 2_力扣797_所有可能的路径
算法·leetcode·深度优先
xiaoxue..8 小时前
合并两个升序链表 与 合并k个升序链表
java·javascript·数据结构·链表·面试
YuTaoShao9 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法一)前后缀分解
算法·leetcode·职场和发展