LeetCode:142环形链表Ⅱ

java 复制代码
/**
 * Definition for singly-linked list.
 * class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
    public ListNode detectCycle(ListNode head) {
        ListNode slow = head;
        ListNode fast = head;
    
        while(fast != null && fast.next != null){
            //快指针走两步慢指针一步
            slow = slow.next;
            fast = fast.next.next;
            //快慢指针相遇
            if(slow == fast){
                ListNode index1 = slow;
                ListNode index2 = head;
                //两指针一步一步走
                while(index1 != index2){
                    index1 = index1.next;
                    index2 = index2.next;
                }
                return index1;
            }
        }
        return null;
    }
}

假设a表示从起点到环入口的距离;b表示从环入口到相遇点的距离;c表示从相遇点继续往前走到环入口的距离。

慢节点走过的距离:a+b

快节点走过的距离:a+b+n(b+c),表示快节点在圈中多转了n圈

快节点是慢节点的两倍,所以2(a+b)=a+b+n(b+c)

a+b=n(b+c)

a=n(b+c)-b

a=(n-1)(b+c)+c

a的长度等于快节点在环里面转(n-1)圈后再走c的长度

所以将慢节点放到head,快节点放到相遇位置,然后以相同速度前移,最终会得到相遇的位置

相关推荐
回忆2012初秋2 小时前
C# 射线算法:判断GPS点是否在车辆工作区域内
linux·算法·c#
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章51-点查找
图像处理·人工智能·opencv·算法·计算机视觉
黎雁·泠崖2 小时前
二叉树遍历:LeetCode 144 / 94 / 145 之递归 + 分治 + 非递归
java·数据结构·算法·leetcode
凌波粒2 小时前
LeetCode--347.前 K 个高频元素(栈和队列)
java·数据结构·算法·leetcode
FluxMelodySun2 小时前
机器学习(三十二) 半监督学习-基于分歧的方法与半监督聚类
人工智能·算法·机器学习
steem_ding2 小时前
C++ 回调函数详解
开发语言·c++·算法
会编程的土豆2 小时前
字符串知识(LCS,LIS)区分总结归纳
开发语言·数据结构·c++·算法
北顾笙9802 小时前
day25-数据结构力扣
数据结构·算法·leetcode
lxh01132 小时前
最接近的三数之和
java·数据结构·算法