LeetCode 分类刷题:141. 环形链表

题目

给你一个链表的头节点 head ,判断链表中是否有环。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递。仅仅是为了标识链表的实际情况。

如果链表中存在环 ,则返回 true 。 否则,返回 false

解析

前置题目:LeetCode 分类刷题:876. 链表的中间结点

同样设置快慢指针

如果链表中存在环,那么慢指针到环的入口时,快指针肯定已经入环了。因为快指针走两步的时间慢指针走一步,所以相对速度为1,则快指针一定会遇到慢指针。

如果链表中不存在环,则快指针会先遍历完链表,指向空。

答案

javascript 复制代码
var hasCycle = function(head) {
    let slow = head, fast = head; // 乌龟和兔子同时从起点出发
    while (fast && fast.next) {
        slow = slow.next; // 乌龟走一步
        fast = fast.next.next; // 兔子走两步
        if (fast === slow) { // 兔子追上乌龟(套圈),说明有环
            return true;
        }
    }
    return false; // 访问到了链表末尾,无环
};

// 作者:灵茶山艾府
// 链接:https://leetcode.cn/problems/linked-list-cycle/solutions/1999269/mei-xiang-ming-bai-yi-ge-shi-pin-jiang-t-c4sw/
// 来源:力扣(LeetCode)
// 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

复杂度分析

时间复杂度:O(n),其中 n 是链表的长度。

空间复杂度:O(1)

相关推荐
️是78几秒前
信息奥赛一本通—编程启蒙(3346:【例60.3】 找素数)
数据结构·c++·算法
captain3762 分钟前
map和set
数据结构·算法
qq_416018725 分钟前
实时数据可视化库
开发语言·c++·算法
格林威5 分钟前
工业相机参数解析:曝光时间与运动模糊的“生死博弈”
c++·人工智能·数码相机·opencv·算法·计算机视觉·工业相机
2401_8732046519 分钟前
C++中的策略模式进阶
开发语言·c++·算法
xushichao198924 分钟前
C++中的职责链模式实战
开发语言·c++·算法
清风徐来QCQ30 分钟前
js中的模板字符串
开发语言·前端·javascript
大鹏说大话31 分钟前
数据库查询优化全攻略:从索引设计到架构演进
算法
小O的算法实验室31 分钟前
2025年IEEE TETCI SCI2区,一种用于二次无约束二进制优化的协同神经动力学算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
2301_8184190137 分钟前
C++中的协程编程
开发语言·c++·算法