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步

相关推荐
lxmyzzs1 小时前
【图像算法 - 16】庖丁解牛:基于YOLO12与OpenCV的车辆部件级实例分割实战(附完整代码)
人工智能·深度学习·opencv·算法·yolo·计算机视觉·实例分割
wow_DG2 小时前
【C++✨】多种 C++ 解法固定宽度右对齐输出(每个数占 8 列)
开发语言·c++·算法
Epiphany.5562 小时前
c++最长上升子序列长度
c++·算法·图论
Cx330❀3 小时前
【数据结构初阶】--排序(四):归并排序
c语言·开发语言·数据结构·算法·排序算法
余_弦3 小时前
区块链中的密码学 —— 密钥派生算法
算法·区块链
亲爱的非洲野猪3 小时前
令牌桶(Token Bucket)和漏桶(Leaky Bucket)细节对比
网络·算法·限流·服务
NAGNIP4 小时前
一文读懂LLAMA
算法
烧冻鸡翅QAQ4 小时前
62.不同路径
算法·动态规划
番薯大佬4 小时前
编程算法实例-冒泡排序
数据结构·算法·排序算法
queenlll4 小时前
P2404 自然数的拆分问题(典型的dfs)
算法·深度优先