题解 | #链表中环的入口结点#

链表中环的入口结点

https://www.nowcoder.com/practice/253d2c59ec3e4bc68da16833f79a38e4

//当快慢指针相遇后,让slow继续移动,同时让head开始移动,根据两变量的关系pHead与slow

 //相遇的时候pHead为环的入口点

struct ListNode* EntryNodeOfLoop(struct ListNode* pHead ) {

   struct ListNode* slow=pHead;

    struct ListNode* fast=pHead;

    while(fast!=NULL&&fast->next!=NULL)

    {

        slow=slow->next;

        fast=fast->next->next;

        if(fast==slow)

        {

            while(slow!=pHead)

            {

                slow=slow->next;

                pHead=pHead->next;

            }

            return pHead;

        }

    }

    return NULL;

}

全部评论

相关推荐

程序员小白条:你不是有一段实习了吗,现在找中大厂实习?过段时间要秋招了
我的简历长这样
点赞 评论 收藏
分享
自学java狠狠赚一...:骗你点star的,港卵公司,记得把star收回去
点赞 评论 收藏
分享
06-08 22:25
门头沟学院 Java
从零开始的转码生活:这hr不会打开手机不分青红皂白给所有人群发这句话,过一会再给所有人再发一遍,这肯定会有重复的,不管,再过一会再发一遍
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务