本文已参与「新人创作礼」活动,一起开启掘金创作之路。
- 题号:力扣142
- 知识点:链表,双指针
- 总结 题干:
思路:
- 1.设置一个快指针和一个慢指针,快指针每次走两步,慢指针每次走一步,当快指针和慢指针相遇时,说明有环
- 2.然后再分别从头结点和相遇结点出发两个指针,每次同时移动一步,当这两个指针相遇时的结点就是入环的第一个结点(证明见链接www.programmercarl.com/0142.%E7%8E…)
class Solution {
public:
ListNode *detectCycle(ListNode *head) {
ListNode *slow = head;
ListNode *fast = head;
while(fast != nullptr && fast->next != nullptr && fast->next->next != nullptr){
fast = fast->next->next;
slow = slow->next;
if (slow == fast){
// 改为步长为1,找head和当前点相交的位置
ListNode *index1 = head;
ListNode *index2 = slow;
while(index1 != index2){
index1 = index1->next;
index2 = index2->next;
}
return index1;
}
}
return nullptr;
}
};