力扣热门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;
    }
}
相关推荐
浅念-7 小时前
递归解题指南:LeetCode经典题全解析
数据结构·算法·leetcode·职场和发展·排序算法·深度优先·递归
Kiling_07047 小时前
Java集合进阶:Set与Collections详解
算法·哈希算法
智者知已应修善业8 小时前
【51单片机89C51及74LS273、74LS244组成】2022-5-28
c++·经验分享·笔记·算法·51单片机
洛水水8 小时前
【力扣100题】33.验证二叉搜索树
算法·leetcode·职场和发展
SimpleLearingAI8 小时前
聚类算法详解
算法·数据挖掘·聚类
刀法如飞9 小时前
Go 字符串查找的 20 种实现方式,用不同思路解决问题
算法·面试·程序员
Dlrb121111 小时前
C语言-指针数组与数组指针
c语言·数据结构·算法·指针·数组指针·指针数组·二级指针
WL_Aurora11 小时前
Python 算法基础篇之集合
python·算法
平行侠11 小时前
A15 工业路由器IP前缀高速检索与内存压缩系统
网络·tcp/ip·算法
阿旭超级学得完12 小时前
C++11包装器(function和bind)
java·开发语言·c++·算法·哈希算法·散列表