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

链表中环的入口结点

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

方法一:快慢指针相遇法

注意:

  • (1)fast以2倍速度绕圈和slow相遇之后回到起点
  • (2)回到起点后,fast与slow同频移动直至在入口处相遇
  • (3)必须考虑无环为空的情况

原理:a = c + (k-1)(b+c)

public ListNode EntryNodeOfLoop(ListNode pHead) {
        if(pHead == null)return null;//(1)空链表
        ListNode fast = pHead;
        ListNode slow = pHead;
        while(fast != null && fast.next!=null){
            fast = fast.next.next;
            slow = slow.next;
            if(slow == fast)break;
        }
        //(2)无环,所以链表结尾为空
        if(fast == null || fast.next==null)return null;
        fast = pHead;
        //fast回到起点后,变慢了!按slow同样的速度前进!
        while(fast != slow){
            fast = fast.next;
            slow = slow.next;
        }
        return slow;
    }

方法二:哈希集合法

哈希集合判定是否已存储过元素了

public ListNode EntryNodeOfLoop(ListNode pHead) {
    Hashset<ListNode> set = new Hashset<>();
    while(cur!=null){
        if(set.contains(cur))
           return cur;
        set.add(cur);
        cur = cue.next;
    }
    return null;
}
#剑指offer#
全部评论

相关推荐

程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
深夜书店vv:腾讯是这样的,去年很多走廊都加桌子当工区
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务