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

链表中环的入口结点

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

# -*- coding:utf-8 -*-
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None
class Solution:
    def EntryNodeOfLoop(self, pHead):
        # write code here
        slow = pHead
        fast = pHead
        while slow:
            slow = slow.next
            # 判断环
            if fast.next:
                fast = fast.next.next
                if not fast:
                    return None
                # 若有环,则从相遇点到环入口的步数=从起点到环入口的步数
                if fast == slow:
                     p = pHead
                     q = fast
                     while p and q:
                        if p == q:
                            return p
                        p = p.next
                        q = q.next
                    # 只需要遍历2次链表,所以是O(n)
        return None

全部评论

相关推荐

字节一直是我的白月光,考虑到转正还是拒了日常实习。
从今天开始狠狠卷JVAV_癫:为什么你释放的offer没流到我头上
点赞 评论 收藏
分享
水墨不写bug:疑似没有上过大学
点赞 评论 收藏
分享
仁者伍敌:牛子这些人还会点一个自动回复,boss都不带回复的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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