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步

相关推荐
数研小生12 小时前
构建命令行单词记忆工具:JSON 词库与艾宾浩斯复习算法的完美结合
算法·json
芒克芒克12 小时前
LeetCode 题解:除自身以外数组的乘积
算法·leetcode
Python 老手12 小时前
Python while 循环 极简核心讲解
java·python·算法
@Aurora.12 小时前
优选算法【专题九:哈希表】
算法·哈希算法·散列表
爱看科技13 小时前
微美全息(NASDAQ:WIMI)研究拜占庭容错联邦学习算法,数据安全与隐私保护的双重保障
算法
qq_4171292513 小时前
C++中的桥接模式变体
开发语言·c++·算法
YuTaoShao14 小时前
【LeetCode 每日一题】3010. 将数组分成最小总代价的子数组 I——(解法二)排序
算法·leetcode·排序算法
吴维炜15 小时前
「Python算法」计费引擎系统SKILL.md
python·算法·agent·skill.md·vb coding
Σίσυφος190016 小时前
PCL Point-to-Point ICP详解
人工智能·算法
玄〤16 小时前
Java 大数据量输入输出优化方案详解:从 Scanner 到手写快读(含漫画解析)
java·开发语言·笔记·算法