给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null。
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};
*/
class Solution {
public:
ListNode* EntryNodeOfLoop(ListNode* pHead)
{
ListNode*slow=pHead;
ListNode*fast=pHead;
while(fast!=NULL&&fast->next!=NULL){
fast=fast->next->next;
slow=slow->next;
if(slow==fast){
fast=pHead;
while(slow!=fast){
slow=slow->next;
fast=fast->next;
}
return slow;
}
}
return NULL;
}
};
我的解析里面写的还是比较清楚的。这里简单说明一下。解析里面数学证明了如果有环的话,快慢指针一定会相遇的。后面还证明了在相遇之后,把fast指针拿到链表头,slow从相遇点向后移动,现在,二者都是每次移动一个位置。二者的初次相遇点就是链表的环的入口。
谢谢阅读!
本文地址:https://blog.csdn.net/weixin_40007143/article/details/107297812
如对本文有疑问, 点击进行留言回复!!
MySQL-关系代数-并、交、差、等值连接、自然连接、左连接。。。
网友评论