【LeetCode热题100】【链表】环形链表

题目链接:141. 环形链表 - 力扣(LeetCode)

判断一个链表有没有环可以用快慢指针的方法,如果没有环,那么最终可以让两个指针中一个为空,如果有环,那么快指针终会与慢指针相遇

复制代码
class Solution {
public:
    bool hasCycle(ListNode *head) {
        if (head == nullptr || head->next == nullptr)
            return false;
        ListNode *fast = head->next;
        ListNode *slow = head;
        while (fast != slow) {
            if (fast == nullptr || fast->next == nullptr)
                return false;
            fast = fast->next->next;
            slow = slow->next;
        }
        return true;
    }
};
相关推荐
Lucky_ldy10 分钟前
C语言学习: 自定义类型—联合和枚举
c语言·学习·算法
gumichef10 分钟前
栈和队列(2)
数据结构·算法·链表
进击的荆棘12 分钟前
递归、搜索与回溯——综合(下)
c++·算法·leetcode·深度优先·dfs
不知名的忻13 分钟前
归并排序(Java)
java·算法·排序算法
YUDAMENGNIUBI3 小时前
day20_逻辑回归
算法·机器学习·逻辑回归
澈2077 小时前
C++并查集:高效解决连通性问题
java·c++·算法
旖-旎9 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
企客宝CRM10 小时前
2026年中小企业CRM选型指南:企客宝CRM处于什么位置?
android·算法·企业微信·rxjava·crm
橙淮10 小时前
二叉树核心概念与Java实现详解
数据结构·算法
米罗篮10 小时前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程