LeetCode 热题100 141. 环形链表

news/2025/2/26 9:36:33

LeetCode 热题100 | 141. 环形链表

大家好,今天我们来解决一道经典的算法题——环形链表。这道题在 LeetCode 上被标记为简单难度,要求我们判断一个链表中是否存在环。下面我将详细讲解解题思路,并附上 Python 代码实现。


题目描述

给定一个链表的头节点 head,判断链表中是否有环。如果链表中有某个节点可以通过连续跟踪 next 指针再次到达,则链表中存在环。返回 true 表示链表中有环,否则返回 false

示例:

输入:head = [3,2,0,-4], pos = 1
输出:true
解释:链表中有一个环,其尾部连接到第二个节点。

解题思路

判断链表是否有环,常用的方法是 快慢指针法(Floyd 判圈算法)。快慢指针法的核心思想是使用两个指针,一个快指针和一个慢指针,快指针每次走两步,慢指针每次走一步。如果链表中有环,快指针最终会追上慢指针;如果没有环,快指针会到达链表末尾。

核心思想
  1. 快慢指针
    • 初始化两个指针 slowfast,都指向链表的头节点 head
    • slow 每次移动一步,fast 每次移动两步。
    • 如果 fastfast.nextNone,说明链表没有环。
    • 如果 slowfast 相遇,说明链表有环。

代码实现

class ListNode:
    def __init__(self, val=0, next=None):
        self.val = val
        self.next = next

def hasCycle(head):
    """
    :type head: ListNode
    :rtype: bool
    """
    if not head or not head.next:
        return False
    
    slow = head  # 慢指针
    fast = head  # 快指针
    
    while fast and fast.next:
        slow = slow.next  # 慢指针走一步
        fast = fast.next.next  # 快指针走两步
        if slow == fast:  # 如果相遇,说明有环
            return True
    
    return False  # 如果没有相遇,说明无环

代码解析

  1. 初始化

    • 如果链表为空或只有一个节点,直接返回 False,因为不可能有环。
    • 初始化两个指针 slowfast,都指向链表的头节点 head
  2. 遍历链表

    • 使用 while 循环遍历链表,直到 fastfast.nextNone
    • slow 每次移动一步,fast 每次移动两步。
    • 如果 slowfast 相遇,说明链表有环,返回 True
  3. 返回结果

    • 如果遍历结束后没有相遇,说明链表无环,返回 False

复杂度分析

  • 时间复杂度:O(n),其中 n 是链表的节点数。快指针最多遍历链表两次。
  • 空间复杂度:O(1),只使用了常数个额外空间。

示例运行

示例 1
# 创建链表 [3,2,0,-4],并形成环
head = ListNode(3)
head.next = ListNode(2)
head.next.next = ListNode(0)
head.next.next.next = ListNode(-4)
head.next.next.next.next = head.next  # 形成环

# 判断链表是否有环
print(hasCycle(head))  # 输出: True
示例 2
# 创建链表 [1,2],并形成环
head = ListNode(1)
head.next = ListNode(2)
head.next.next = head  # 形成环

# 判断链表是否有环
print(hasCycle(head))  # 输出: True
示例 3
# 创建链表 [1],无环
head = ListNode(1)

# 判断链表是否有环
print(hasCycle(head))  # 输出: False

总结

通过快慢指针法,我们可以高效地判断链表是否有环。这种方法的时间复杂度为 O(n),空间复杂度为 O(1),能够处理较大的输入规模。希望这篇题解对你有帮助!如果还有其他问题,欢迎继续提问!

关注我,获取更多算法题解和编程技巧!


http://www.niftyadmin.cn/n/5868485.html

相关文章

DeepSeek开源周Day2:DeepEP - 专为 MoE 模型设计的超高效 GPU 通信库

项目地址:https://github.com/deepseek-ai/DeepEP 开源日历:2025-02-24起 每日9AM(北京时间)更新,持续五天 (2/5)! ​ ​ 引言 在大模型训练中,混合专家模型(Mixture-of-Experts, MoE)因其动…

锂电池使用和存储电压

表格补充说明: 每列数据中,2S和3S电池的数值都是单电芯数值的2倍和3倍;对于其他电压的电池,将单电芯数值乘以相应S数即可;理论上单个电芯过放电压为3.0V,实际中为了保险,电压降到3.6V即需充电。…

深度学习笔记线性代数方面,记录一些每日学习到的知识

记录一些每日学习到的新知识: torch:Torch是一个有大量机器学习算法支持的科学计算框架,是一个与Numpy类似的张量(Tensor)操作库 jupyter:Jupyter Notebook 的本质是一个 Web 应用程序,便于创建和共享程序文档&#…

centos系统MBR格式转换成gpt格式 (华为云)

在华为云上的centos7.9系统MBR格式转换成GPT格式的步骤 华为云上关于转换的步骤 这个链接里面 gdisk -g /dev/vda 是不对的,-g参数是新创建一个分区,慎用 自己步骤如下:(已经试验过) 1、gdisk /dev/sda (这里是盘 不…

请谈谈 React 中的状态管理,如何使用 Context API 和 Redux 进行状态管理?

一、Context API 深度应用 1. 核心实现原理 通过createContext创建上下文对象,使用Provider组件包裹需要共享状态的组件树,子组件通过useContext Hook或Consumer组件消费数据。 代码示例(主题切换场景): // 创建上…

反制无人机详细全面介绍

一、反制系统的核心架构 侦测识别层 采用雷达、光电/红外传感器、无线电频谱监测等技术实现全空域覆盖。毫米波雷达可探测微型无人机,声学探测适用于低噪声环境4,而被动射频定位技术可追踪2-8公里范围内的目标。多传感器融合技术(如雷达光电A…

React(10)

项目实践--创建项目 在store的modules中创建相关的子仓库暴露到仓库index文件中 导入creatSlice和axios 创建仓库 和数据的异步修改方法 // 编写store // 导入createSlice和axios import { createSlice } from "reduxjs/toolkit"; import axios from "axios&…

【10】RUST的迭代器与闭包

文章目录 闭包(Closures)定义捕获方式:迭代器(Iterator)核心方法:创建方式:适配器(Adapter)常见适配器及示例消费方法(Consumer)所有权与引用处理性能与惰性求值闭包(Closures) 类比C++里的lambda表达式 闭包是能够捕获其所在环境变量的匿名函数,支持灵活的类型推…