链表:链表中环的入口结点
Posted icehole
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了链表:链表中环的入口结点相关的知识,希望对你有一定的参考价值。
/* 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,
所以到这结束。
*/
以上是关于链表:链表中环的入口结点的主要内容,如果未能解决你的问题,请参考以下文章