码迷,mamicode.com
首页 > 其他好文 > 详细

链表:链表中环的入口结点

时间:2020-01-01 21:05:30      阅读:104      评论:0      收藏:0      [点我收藏+]

标签:lin   pre   结束   alt   comm   null   lis   turn   div   

/*
struct ListNode {
    int val;
    struct ListNode *next;
    ListNode(int x) :
        val(x), next(NULL) {
    }
};
*/
class Solution {
public:
    ListNode* EntryNodeOfLoop(ListNode* pHead)
    {
        ListNode *pfast = pHead;
        ListNode *pslow = pHead;
        while(pfast != nullptr && pfast->next != nullptr){
            pfast = pfast->next->next;
            pslow = pslow->next;
            if(pfast == pslow){
                break;
            }
        }
        if(pfast == nullptr || pfast->next == nullptr) return NULL;
        pfast = pHead;
        while(pfast != pslow){
            pslow = pslow->next;
            pfast = pfast->next;
        }
        return pslow;
    }
};


/*
时间复杂度为O(n),两个指针,一个在前面,另一个紧邻着这个指针,在后面。
两个指针同时向前移动,每移动一次,前面的指针的next指向NULL。
也就是说:访问过的节点都断开,最后到达的那个节点一定是尾节点的下一个,
也就是循环的第一个。
这时候已经是第二次访问循环的第一节点了,第一次访问的时候我们已经让它指向了NULL,
所以到这结束。
*/

  

链表:链表中环的入口结点

标签:lin   pre   结束   alt   comm   null   lis   turn   div   

原文地址:https://www.cnblogs.com/icehole/p/12129715.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!