题解 | #链表中环的入口结点#

链表中环的入口结点

http://www.nowcoder.com/practice/253d2c59ec3e4bc68da16833f79a38e4

最难的地方

不仅仅是双指针就是想通第一次相遇后,调整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;
    }
}
全部评论
难点在重置fast指针
1 回复 分享
发布于 2022-02-15 12:06
check 环是否存在,也有小技巧;
点赞 回复 分享
发布于 2022-06-29 07:41

相关推荐

喜欢喜欢喜欢:这是我见过最长最臭的简历
点赞 评论 收藏
分享
头像
05-16 11:16
已编辑
东华理工大学 Java
牛客737698141号:盲猜几十人小公司,庙小妖风大,咋不叫她去4️⃣呢😁
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务