DAY 31 leetcode 142--链表.环形链表

题号:142

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

java 复制代码
public class Solution {
    public ListNode detectCycle(ListNode head) {
        ListNode slow=head;
        ListNode fast=head;
        while(true){
            if(fast==null||fast.next==null)return null;
            fast=fast.next.next;
            slow=slow.next;
            if(fast==slow)
            break;
        }
        fast=head;
        while(slow!=fast){
            fast=fast.next;
            slow=slow.next;
        }
        return slow;
    }
}

重点:

第一次相遇

首先判断是否有环,让fast和slow同时从head出发,fast一次走两步,slow一次走一步,假如存在环则一定能够相遇

设都走了s次,则fast 走了2s步,slow走了s步

而相遇时,设fastslow多走了n圈,则有 2s=s+nb (设从头节点到环入口前长度为a 环周长为b)

化简得s=nb 即slow走了nb长度

第二次相遇

假如我想让节点在入口处停下,则需要从head开始走a+nb步,而已知slow已经走了nb步,此时slow想要在入口处停下,即要再走a步,那么就可以可以再次使用双指针,即可把fast指针退回到head,和slow一样每次走一格,当两者相遇时即slow和fast都又走了a步

相关推荐
2401_8414956424 分钟前
【机器学习】朴素贝叶斯法
人工智能·python·数学·算法·机器学习·概率论·朴素贝叶斯法
时间醉酒39 分钟前
逻辑回归(四):从原理到实战-训练,评估与应用指南
人工智能·python·算法·机器学习·逻辑回归
Zheng照邻、1 小时前
VLM Prompt优化之 DynaPrompt(ICLR 2025)论文总结
人工智能·算法·语言模型·prompt·aigc
CoovallyAIHub1 小时前
机器人“大脑”遭遇认知冻结攻击!复旦等提出FreezeVLA,一张图片即可瘫痪多模态大模型
深度学习·算法·计算机视觉
无敌最俊朗@1 小时前
死锁 (Deadlock) 深度解析
算法
西阳未落2 小时前
欧拉路径与欧拉回路
算法·深度优先
Swift社区2 小时前
LeetCode 390 消除游戏
算法·leetcode·游戏
橘颂TA3 小时前
【剑斩OFFER】优雅的解法——三数之和
算法
我爱工作&工作love我3 小时前
2024-CSP-J T3 小木棍
算法·动态规划
DatGuy3 小时前
Week 18: 深度学习补遗:Stacking和量子运算Deutsch算法
人工智能·深度学习·算法