leetcode 141 判断链表中是否存在环

leetcode 141 判断链表中是否存在环

题目描述

给定一个单链表的头节点 head,判断链表中是否存在环。如果链表中存在环,则返回 true,否则返回 false

注意: 链表节点定义如下:

java 复制代码
class ListNode {
    int val;
    ListNode next;
    ListNode(int x) {
        val = x;
        next = null;
    }
}

思路

我们使用快慢指针的方法来检测链表中是否存在环。具体步骤如下:

  1. 初始化一个慢指针 slow 和一个快指针 fast,初始位置分别为链表头部。
  2. 在每一步中,慢指针 slow 移动一步,快指针 fast 移动两步。
  3. 如果链表中存在环,那么 fast 指针最终会追上或者超过 slow 指针。

解法

java 复制代码
/**
 * Definition for singly-linked list.
 * class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
    public boolean hasCycle(ListNode head) {
        if (head == null || head.next == null) {
            return false;
        }
        ListNode slow = head;
        ListNode fast = head.next;
        while (fast != null && fast.next != null) {
            if (fast == slow) {
                return true;
            }
            fast = fast.next.next;
            slow = slow.next;
        }
        return false;
    }
}

复杂度分析

  • 时间复杂度:O(n),其中 n 为链表中节点的个数。在最坏情况下,快指针需要遍历整个链表。
  • 空间复杂度:O(1),我们只使用了常数级别的额外空间。
相关推荐
Shan120512 小时前
无向图的Hierholzer算法流程(二)
算法
gihigo199812 小时前
基于蒙特卡洛的异常值剔除(RANSAC + MC置信区间)—MATLAB实现
开发语言·算法·matlab
Asize13 小时前
数组数据结构底层:从灵活到陷阱
前端·javascript·算法
hairenwangmiao13 小时前
B4041 [GESP202409 四级] 区间排序
算法·排序
人道领域13 小时前
【LeetCode刷题日记】47.全排列Ⅱ
java·开发语言·算法·leetcode
漂流瓶jz13 小时前
UVA-1606 两亲性分子 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·向量·aoapc·算法竞赛入门经典·atan2·浮点
Navigator_Z13 小时前
LeetCode //C - 1095. Find in Mountain Array
c语言·算法·leetcode
不会就选b14 小时前
算法日常・每日刷题--<二分查找>1
算法
「維他檸檬茶」14 小时前
大模型算法学习2026.6.13
学习·算法
叫我:松哥14 小时前
基于Python的共享单车租赁数据分析与预测系统,技术栈flask+boostrap+随机森林+XGBoost
人工智能·python·深度学习·算法·随机森林·数据分析·flask