Leetcode42-环形链表

题目

给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。

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

不允许修改 链表。

示例 1:

输入:head = [3,2,0,-4], pos = 1

输出:返回索引为 1 的链表节点

解释:链表中有一个环,其尾部连接到第二个节点。

代码

java 复制代码
static public ListNode hasCycle_StartNode(ListNode head) {
    ListNode slow = head, fast = head; // 将 fast 的起始位置设置为 head
    while (fast != null && fast.next != null) {
        slow = slow.next;
        fast = fast.next.next;
        if (slow == fast) {// 此时slow和fast在环的中相遇,但是相遇的点不一定是环的入口点,因为进入指针环的时机是不一样的
            ListNode cycle = head;// 重置一个新节点,走a的距离,就可以和slow后续的移动汇合,且一定是环开始的节点
            while (cycle != slow) {
                cycle = cycle.next;
                slow = slow.next;
            }
            return cycle;
        }
    }
    return null;
}

总结

a:从链表头到环的起始节点的距离。

b:从环的起始节点到快慢指针相遇点的距离。

c:环的长度。

慢指针 slow 从头节点开始,走了 a + b 的距离到达相遇点。

快指针 fast 从头节点开始,走了 a + b + n*c 的距离(其中 n 是快指针在环内绕的圈数)。

当快慢指针相遇时,有以下关系:

  • slow 走的距离:a + b
  • fast 走的距离:a + b + n*c

由于快指针的速度是慢指针的两倍,得出: 2(a + b) = a + b + nc => a + b = n c

这表明慢指针走的距离a+b是环长度的整数倍

相关推荐
shehuiyuelaiyuehao8 小时前
算法1,移动零
数据结构·算法·排序算法
shehuiyuelaiyuehao8 小时前
算法2,复写零
数据结构·算法
像污秽一样8 小时前
算法设计与分析-算法效率分析基础-习题1.1
c语言·数据结构·c++·算法
wen__xvn18 小时前
模拟题刷题3
java·数据结构·算法
Neteen19 小时前
【数据结构-思维导图】第二章:线性表
数据结构·c++·算法
礼拜天没时间.19 小时前
力扣热题100实战 | 第25期:K个一组翻转链表——从两两交换到K路翻转的进阶之路
java·算法·leetcode·链表·递归·链表反转·k个一组翻转链表
故事和你9120 小时前
sdut-程序设计基础Ⅰ-实验二选择结构(1-8)
大数据·开发语言·数据结构·c++·算法·优化·编译原理
像素猎人21 小时前
数据结构之顺序表的插入+删除+查找+修改操作【主函数一步一输出,代码更加清晰直观】
数据结构·c++·算法
季明洵21 小时前
二叉树的最小深度、完全二叉树的节点个数、平衡二叉树、路径总和、从中序与后序遍历序列构造二叉树
java·数据结构·算法·leetcode·二叉树
小龙报1 天前
【算法通关指南:算法基础篇】二分算法: 1.A-B 数对 2.烦恼的高考志愿
c语言·开发语言·数据结构·c++·vscode·算法·二分