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(冲出了边界)
相关推荐
zzz_23681 小时前
【Java基础】链表的七十二变——从LRU缓存到手写浏览器前进后退
java·链表·缓存
Irissgwe3 小时前
顺序表和链表
数据结构·c++·链表·c·顺序表·线性表
玖玥拾3 小时前
C/C++ 数据结构(四)链表与STL容器
c语言·数据结构·c++·链表·stl库
满怀冰雪3 小时前
第15篇-链表基础-反转链表-合并链表与快慢指针
java·算法·链表
玖玥拾4 小时前
C/C++ 数据结构(一)基础概念、线性表链表
c语言·数据结构·c++·链表
暖阳华笺4 小时前
【数据结构与算法】哈希专题
数据结构·c++·算法·leetcode·哈希算法
LuminousCPP4 小时前
数据结构 - 单链表第二篇:单链表进阶操作
c语言·数据结构·笔记·链表
玖玥拾4 小时前
C/C++ 数据结构(三)链表核心算法
c语言·数据结构·c++·链表
AKA__Zas4 小时前
芝士算法(滑动窗口片 2.0)
java·算法·leetcode·学习方法
四代水门4 小时前
LeetCode刷算法题(C++)
c++·算法·leetcode