LeetCode 142. 环形链表 II

目录

1.原题链接:

2.快慢指针:

证明:

代码实现:

3.提交结果:

4.读书分享:


1.原题链接:

142. 环形链表 II

2.快慢指针:

温馨提示: 建议看这题之前先把相交链表环形链表看了,这样,来理解本题就会简单些。

160.相交链表

141. 环形链表

证明:

设:链表的头结点到入环结点之间的距离为 S,入环结点到相遇结点 之间的距离为X,环的周长为C;

慢指针走的路程为:S+X(慢指针不可能在环里转了一圈(或以上)才到相遇点)

快指针走的路程:S+C+X。

所以,可以得到:S+C+X=2(S+X)

S+X=C

S=C-X

通过公式S=C-X,我们可以得到当slow指针与fast指针在环内相遇时,我们可以使用一个指针指向相遇点,一个指向头结点,让它们同时移动,最后,当两个指针指向同一个位置时,这个结点就是入环结点。

真的是这样吗?

其实,fast走的路程是有问题的。

通过上图,我们可以看到,当我前面的直线很长,后面的环很小时,我们会发现fast指针会在环里面走很多圈,而不只是1圈 。(我们可以假设一种情况,slow在直线上走一步,fast就在环内走一圈,此时环内刚好只有两个结点)

我们这里假设fast与slow相遇时,它已经在环内转了N圈了。

所以,快指针走的路程为:S+N*C+X。所以上面的情况只是快指针走的路程的子集。

所以,2(S+X)=S+N*C+X

S+X=N*C

S=N*C-X

S=(N-1)C+C-X

我们会发现fast在环内走的N-1圈都是没有必要的,它只是在精神内耗自己,没有什么意义,毕竟它(slow)还没进环,还不知道你(fast)为了遇到它,有多么努力。所以我们这里可以暂时不看(N-1)*C,剩下S=C-X,同样可以得到前面的结论 ------ 使用一个指针指向相遇点,一个指向头结点,让它们同时移动,最后,当两个指针指向同一个位置时,这个结点就是入环结点

代码实现:

objectivec 复制代码
typedef struct ListNode ListNode;
struct ListNode *detectCycle(struct ListNode *head) 
{
    ListNode* fast = head;
    ListNode* slow = head;
    while (fast != NULL && fast->next!=NULL)
    {
        fast = fast->next->next;
        slow = slow->next;
        if (fast == slow)//fast与slow到了相遇点
        {
            ListNode* accept = fast;//用一个指针指向相遇点
            while (accept != head)
            {
                //链表的头指针与相遇点指针同时移动
                head = head->next;
                accept = accept->next;
            }
            return head;//找到了入口结点
        }
    }
    return NULL;//不存在环
}

3.提交结果:

4.读书分享:

道德经·第四十七章》:

不出户,知天下;不闚(kuī)牖(yǒu),见天道。

其出弥远,其知弥少。

是以圣人不行而知,不见而名,不为而成。

解释:

足不出门户,已知万物况相生长;眼不望窗外,已晓气候发生变化。

越向外奔逐,对道的认识也越少。

所以圣人不必体验,就能察觉事物已经发展;不必观看,就已洞悉事态正起变化;无须操纵,不横加干涉,事业自然水到渠成。

相关推荐
QuantumStack1 小时前
【C++ 真题】P1104 生日
开发语言·c++·算法
写个博客2 小时前
暑假算法日记第一天
算法
绿皮的猪猪侠2 小时前
算法笔记上机训练实战指南刷题
笔记·算法·pta·上机·浙大
hie988943 小时前
MATLAB锂离子电池伪二维(P2D)模型实现
人工智能·算法·matlab
杰克尼3 小时前
BM5 合并k个已排序的链表
数据结构·算法·链表
.30-06Springfield4 小时前
决策树(Decision tree)算法详解(ID3、C4.5、CART)
人工智能·python·算法·决策树·机器学习
我不是哆啦A梦4 小时前
破解风电运维“百模大战”困局,机械版ChatGPT诞生?
运维·人工智能·python·算法·chatgpt
xiaolang_8616_wjl4 小时前
c++文字游戏_闯关打怪
开发语言·数据结构·c++·算法·c++20
small_wh1te_coder4 小时前
硬件嵌入式学习路线大总结(一):C语言与linux。内功心法——从入门到精通,彻底打通你的任督二脉!
linux·c语言·汇编·嵌入式硬件·算法·c
挺菜的4 小时前
【算法刷题记录(简单题)002】字符串字符匹配(java代码实现)
java·开发语言·算法