标签: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