142. 环形链表 II

99 阅读1分钟

本文已参与「新人创作礼」活动,一起开启掘金创作之路。

  • 题号:力扣142
  • 知识点:链表,双指针
  • 总结 题干:

QQ截图20220422224006.png

QQ截图20220422224007.png

QQ截图20220522094937.png 思路:

  • 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;
    }
};