题目描述
给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null。
分析
从上图中可以看出,环的入口结点和其他结点的区别:环的入口结点是有两个指针指向的,其他结点除了头结点都是只有一个指针指向的。
使用断链法,在当前结点访问完毕后,断掉指向当前结点的指针。因此,最后一个被访问的结点一定是入口结点。
定义两个指针,一个在前面,另一个在后面,紧邻着这个指针。
两个指针同时向前移动,每移动一次,后面指针的next指向NULL。
也就是说:访问过的节点都断开,最后到达的那个节点一定是尾节点的下一个,也就是循环的第一个。
这时候已经是第二次访问循环的第一节点了,第一次访问的时候我们已经让它指向了NULL,所以到这结束。
断链法的弊端是破坏了链表原来的结构。
代码
/*
struct ListNode {
int val;
struct ListNode *next;
ListNode(int x) :
val(x), next(NULL) {
}
};
*/
class Solution {
public:
ListNode* EntryNodeOfLoop(ListNode* pHead)
{
if(pHead->next == nullptr )
return nullptr;
ListNode* behind = pHead;
ListNode* front = pHead->next;
while(front){
behind->next=nullptr;
behind = front;
front = front->next;
}
return behind;
}
};