LeetCode 刷题 [C++] 第141题.环形链表

题目描述

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

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

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

题目分析

快慢指针特性 每轮移动之后快指针和慢指针间的距离会加一。

  1. 通过分析题意,可以使用快慢指针来解决该问题。
  2. 假设链表中存在环,当慢指针进入环后,快指针已经进入环并移动了若干次;
  3. 此时就可以看成快指针追击慢指针的问题,假设此时快指针和慢指针间的间距为gap,每次移动后,快指针与慢指针间的间距会缩短1,因此,当移动gap次后,快指针追上慢指针。
  4. 如果链表中不存在环,则快指针与慢指针不会相遇,正常移动到链表尾部结束即可。

Code

cpp 复制代码
class Solution {
public:
    bool hasCycle(ListNode *head) {
        ListNode* fast = head;
        ListNode* slow = head;
        while (nullptr != fast && nullptr != fast->next) {
            fast = fast->next->next;
            slow = slow->next;
            if (fast == slow) {
                return true;
            }
        }
        return false;
    }
};
相关推荐
charlie11451419114 分钟前
嵌入式C++教程实战之Linux下的单片机编程:从零搭建 STM32 开发工具链(5):调试进阶篇 —— 从 printf 到完整 GDB 调试环境
linux·c++·单片机·学习·嵌入式·c
paeamecium28 分钟前
【PAT】 - Course List for Student (25)
数据结构·c++·算法·pat考试
小黄人软件32 分钟前
MFC为什么不报空指针异常 2宏定义不改源码 用替换 用Log函数替换printf等 #define printf Log 优化版底层类Log显示
c++·mfc
wen__xvn39 分钟前
力扣洛谷模拟题刷题2
算法·leetcode·职场和发展
漫随流水1 小时前
c++编程:说反话(1009-PAT乙级)
数据结构·c++·算法
计算机安禾1 小时前
【数据结构与算法】第23篇:树、森林与二叉树的转换
c语言·开发语言·数据结构·c++·线性代数·算法·矩阵
ab1237681 小时前
C++ size() 与 length() 核心笔记
开发语言·c++·笔记
苏宸啊1 小时前
哈希表开放定址法增删改查简单实现
数据结构·c++
AnalogElectronic2 小时前
考研408计算机学科专业基础综合 数据结构复习
数据结构·考研·链表
wfbcg2 小时前
每日算法练习:LeetCode 167. 两数之和 II - 输入有序数组 ✅
算法·leetcode·职场和发展