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步

相关推荐
MicroTech202532 分钟前
微算法科技(MLGO)研发突破性低复杂度CFG算法,成功缓解边缘分裂学习中的掉队者问题
科技·学习·算法
墨染点香1 小时前
LeetCode 刷题【126. 单词接龙 II】
算法·leetcode·职场和发展
aloha_7892 小时前
力扣hot100做题整理91-100
数据结构·算法·leetcode
Tiny番茄2 小时前
31.下一个排列
数据结构·python·算法·leetcode
挂科是不可能出现的2 小时前
最长连续序列
数据结构·c++·算法
前端小L2 小时前
动态规划的“数学之魂”:从DP推演到质因数分解——巧解「只有两个键的键盘」
算法·动态规划
RTC老炮3 小时前
webrtc弱网-ReceiveSideCongestionController类源码分析及算法原理
网络·算法·webrtc
21号 13 小时前
9.Redis 集群(重在理解)
数据库·redis·算法
码农多耕地呗4 小时前
力扣146.LRU缓存(哈希表缓存.映射+双向链表数据结构手搓.维护使用状况顺序)(java)
数据结构·leetcode·缓存
hadage2335 小时前
--- 数据结构 AVL树 ---
数据结构·算法