力扣热门100题之环形链表

判断环形链表,最经典、面试必问的就是 快慢指针法(Floyd 判圈算法),我给你用最清晰的 Java 版 + 原理讲明白。

一、核心思路

  • 慢指针 slow 每次走 1 步
  • 快指针 fast 每次走 2 步
  • 如果链表有环 ,快指针一定会在环里追上慢指针(相遇)
  • 如果链表无环,快指针会走到 null,结束

对应关系就是这么来的(如果对于引用关系有问题可以看一看)

fast---->节点A → 节点B → null

• fast = 当前指向的节点 → 节点 A

• fast.next = 节点 A 的下一个 → 节点 B

• fast.next.next = 节点 B 的下一个 → null

这就是固定规则:谁在 . 前面,就从谁出发往后指。(fast就是节点本身)

java 复制代码
public class Solution {
    public boolean hasCycle(ListNode head) {
        //快慢指针法
        ListNode slow = head;
        ListNode fast = head;

        while(fast != null && fast.next != null){
            slow = slow.next;
            fast = fast.next.next;

            // 相遇 = 有环
            if (slow == fast) {
                return true;
            }
        }
        return false;
    }
}
相关推荐
写代码写到手抽筋6 小时前
5G上行DCI字段判定:端口 流数 PMI选择详解
java·算法·5g
xieliyu.7 小时前
Java算法精讲:双指针(二)
java·开发语言·算法
wayz117 小时前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
8Qi88 小时前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划
三品吉他手会点灯8 小时前
C语言学习笔记 - 44.运算符和表达式 - 运算符2 - 除法与取余运算符
c语言·开发语言·笔记·算法
乐迪信息8 小时前
乐迪信息:AI算法盒子实时识别船舶烟雾与火焰异常
大数据·人工智能·算法·安全·目标跟踪
J-Tony118 小时前
【JVM】根可达算法
jvm·算法
艾iYYY8 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
Lsk_Smion9 小时前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode