[力扣 Hot100]Day25 环形链表

题目描述

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

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

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

出处

思路

经典考研题,使用快慢两指针,若有换两指针必在有限时间O(n)内相遇,若无环则快指针先一步走到链表尾。

代码

cpp 复制代码
class Solution {
public:
    bool hasCycle(ListNode *head) {
        ListNode *fast=head;
        ListNode *slow=head;
        while(fast && slow) {
            fast = fast->next;
            if(!fast) return false;//一定是快指针先到末尾
            else fast = fast->next;
            slow = slow->next;
            if(fast==slow) return true;
        }
        return false;
    }
};
相关推荐
学c语言的枫子4 分钟前
数据结构——基本查找算法
算法
yanqiaofanhua26 分钟前
C语言自学--自定义类型:结构体
c语言·开发语言·算法
sali-tec1 小时前
C# 基于halcon的视觉工作流-章39-OCR识别
开发语言·图像处理·算法·计算机视觉·c#·ocr
芒克芒克1 小时前
LeetCode 面试经典 150 题之判断子序列解题详解
算法
兮山与1 小时前
算法1.0
算法
im_AMBER2 小时前
数据结构 02 线性表
数据结构·算法
2401_841495642 小时前
【计算机视觉】图像去雾技术
人工智能·python·opencv·算法·计算机视觉·技术·图像去雾
河北北重机械9662 小时前
汽车安全性能测试与铸铁底座的重要性
人工智能·算法·机器学习·铸铁底座·铁底座装配·试验台基底座加工
北京地铁1号线3 小时前
数据结构笔试选择题:题组2
算法
XCOSnTh3 小时前
XCOSnTh单片机的串口
c语言·单片机·嵌入式硬件·算法·xcosnth