最难的地方

不仅仅是双指针就是想通第一次相遇后,调整fast位置,调整步调为相同。

alt

code

使用java 通过,使用c++没通过,奇怪

参考 c++: https://blog.nowcoder.net/n/9d3ffa4b004e43d1aff512141d0d7dac 参考 java: https://blog.nowcoder.net/n/b117b5636329454d8a868f8226475c1b


/*
 public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}
*/
public class Solution {

public ListNode EntryNodeOfLoop(ListNode pHead) {
        if(pHead == null) return null;
        // 定义快慢指针
        ListNode slow = pHead;
        ListNode fast = pHead;
        while(fast != null && fast.next != null){
            // 快指针是满指针的两倍速度
            fast = fast.next.next;
            slow = slow.next;
            // 记录快慢指针第一次相遇的结点
            if(slow == fast) break;
        }
        // 若是快指针指向null,则不存在环。66:这个条件容易错!
        if(fast == null || fast.next == null) return null;
  

        // 重新指向链表头部
        fast = pHead;
        // 与第一次相遇的结点相同速度出发,相遇结点为入口结点
        while(fast != slow){
            fast = fast.next;
            slow = slow.next;
        }
        return fast;
    }
}