前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 142. 环形链表 II

LeetCode 142. 环形链表 II

作者头像
freesan44
发布2020-06-08 12:13:51
2600
发布2020-06-08 12:13:51
举报
文章被收录于专栏:freesan44

题目

给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。

为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。 如果 pos 是 -1,则在该链表中没有环。

说明:不允许修改给定的链表。

代码语言:javascript
复制
示例 1:

输入:head = [3,2,0,-4], pos = 1
输出:tail connects to node index 1
解释:链表中有一个环,其尾部连接到第二个节点。
代码语言:javascript
复制
示例 2:

输入:head = [1,2], pos = 0
输出:tail connects to node index 0
解释:链表中有一个环,其尾部连接到第一个节点。
代码语言:javascript
复制
示例 3:

输入:head = [1], pos = -1
输出:no cycle
解释:链表中没有环。

进阶: 你是否可以不用额外空间解决此题?

解题思路

代码语言:javascript
复制
class Solution:
    def detectCycle(self, head: ListNode) -> ListNode:
        # #存值做法
        # numsList = []
        # while head:
        #     if head in numsList:
        #         return head
        #     numsList.append(head)
        #     try:
        #         head = head.next
        #     except:
        #         return None
        # return None
        # 双指针双倍速度走向,当相遇的时候,慢指针再走n步,就走到链表循环入口,而n步也是从头部走到入口的部数
        left = right = head
        while right:
            try:
                left = left.next
                right = right.next.next
            except:
                return None
            if left == right:  # 相遇后,入口的也开始走了
                break
        right = head  # right指针回到表头重新走
        while left and right:
            if left == right:
                return left
            left = left.next
            right = right.next
        return None
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目
  • 解题思路
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档