day4
题中主要是让我们解决两个问题。
第一个问题:怎样判断是否有环?
第二个问题:怎样找到环的入口
针对第一个问题,采用快慢指针的思路。快指针fast,一次走两步。慢指针slow,一次走一步。当
快慢指针相遇时,则说明有环。
那么这里有一个问题:为什么一定会相遇?
因为快指针比慢指针快一步,也就是相对速度大一。那么在环内 快指针就是逐步追赶慢指针。不可能跨过慢指针。但当快指针的速度为一次三个结点时,相对速度为2 ,就有可能跨过慢指针。
针对第二个问题。环的入口。需要用到一些数学推导。
三刷:
1. 忘记 return 的位置
class Solution {
public:
ListNode *detectCycle(ListNode *head) {
// 快慢指针相遇来确定是否有环
ListNode* fast = head;
ListNode* slow = head;
while(fast != NULL && fast->next != NULL) // 结束的条件需要注意,因为fast跳两步
{
fast = fast->next->next;
slow = slow->next;
if(slow == fast) //相遇说明有环
{
// 找环的入口
ListNode* index1 = head;
ListNode* index2 = fast;
while(index1 != index2)
{
index1 = index1 ->next;
index2 = index2->next;
}
return index2;
}
}
return NULL;
}
};