【leetcode】142.环形链表II

cpp 复制代码
struct ListNode *detectCycle(struct ListNode *head) {
    struct ListNode *fast=head;
    struct ListNode *slow=head;
    // 先用快、慢指针找到相遇点
    // 若相遇,则说明存在环
    while(fast!=NULL&&fast->next!=NULL)
    {
        fast=fast->next->next;
        slow=slow->next;
        if(fast==slow)
        {
            // 再找到环的入口
            struct ListNode *p=head;
            // x=(n-1)(y+z)+z
            while(p!=slow)
            {
                p=p->next;
                slow=slow->next;
            }
            return p;
        }
    }
    return NULL;
}
相关推荐
阿里云大数据AI技术2 分钟前
阿里云 AI 搜索开放平台:从算法到业务——AI 搜索驱动企业智能化升级
大数据·人工智能·算法
whltaoin42 分钟前
贪心算法:部分背包问题深度解析
算法·贪心算法
不眠之夜1 小时前
龟兔赛跑:快慢指针法详解(Floyd's Tortoise and Hare Algorithm)
算法
零零壹111 小时前
Apipost自定义函数深度实战:灵活处理参数值秘籍
算法·面试·github
搞程序的心海1 小时前
当机器学习遇见购物车分析:FP-Growth算法全解析
算法
Ludicrouers1 小时前
【Leetcode-Hot100】字母异位词分组
算法·leetcode·职场和发展
爱笑的Sunday1 小时前
【LeetCode 题解】数据库:1321.餐馆营业额变化增长
数据库·sql·leetcode
aw3442 小时前
tiny_dnn_test250101
人工智能·算法·dnn
Bryce-Lin2 小时前
深度学习、图像算法学习记录
深度学习·学习·算法
AndrewHZ2 小时前
【图像处理基石】什么是自动曝光(AE)?
图像处理·人工智能·算法·计算机视觉·ae·isp算法·3a