力扣热题100_链表_142_环形链表 II

文章目录


题目链接

142. 环形链表 II

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

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。如果 pos 是 -1,则在该链表中没有环。注意:pos 不作为参数进行传递,仅仅是为了标识链表的实际情况。

不允许修改 链表。

示例 1:

输入:head = [3,2,0,-4], pos = 1

输出:返回索引为 1 的链表节点

解释:链表中有一个环,其尾部连接到第二个节点。

示例 2:

输入:head = [1,2], pos = 0

输出:返回索引为 0 的链表节点

解释:链表中有一个环,其尾部连接到第一个节点。

示例 3:

输入:head = [1], pos = -1

输出:返回 null

解释:链表中没有环。

解题思路

解法快慢指针

1.利用两个指针,一个慢指针 slow 每次前进一步,快指针 fast 每次前进两步(两步或多步效果是等价的)

2.如果两个指针在链表头节点以外的某一节点相遇(即相等)了,那么说明链表有环

3.否则,如果(快指针)到达了某个没有后继指针的节点时,那么说明没环

4.如果有环,则再定义一个指针 ans,和慢指针一起每次移动一步,两个指针相遇的位置即为入口节点

case1:head = [3,2,0,-4], pos = 1

复制代码
 #fast:0 2 -4
 #slow:2 0 -4
 
 #ans :3  2 0 -4 3 2 0  -4
 #slow:-4 2 0 -4 2 0 -4  2

解题代码

python 复制代码
class Solution:
    def detectCycle(self, head: Optional[ListNode]) -> Optional[ListNode]:
        fast, slow = head, head
        while True:
            if fast == None or fast.next == None:
                return None
            slow = slow.next
            fast = fast.next.next
            if fast == slow:
                break
        ans = head
        while ans != slow:
            ans, slow = ans.next, slow.next
        return ans
相关推荐
flashlight_hi4 分钟前
LeetCode 分类刷题:16. 最接近的三数之和
javascript·数据结构·算法·leetcode
彭军辉15 分钟前
什么是抽象主义人工智能?
人工智能·算法·语言模型·机器人
是店小二呀21 分钟前
【动态规划 | 01背包】动态规划经典:01背包问题详解
算法·动态规划
黑色的山岗在沉睡1 小时前
P10480 可达性统计
数据结构·算法
yu2024111 小时前
异世界历险之数据结构世界(非递归快排,归并排序(递归,非递归))
java·数据结构·排序算法
魏嗣宗1 小时前
缓存系统扩展思考详解
前端·算法·架构
CoovallyAIHub1 小时前
无人机“飞得高”不等于“看得清”?无人机图像识别的算法真相来了!
深度学习·算法·计算机视觉
_Coin_-1 小时前
代码训练营DAY53 第十一章:图论part04
算法·图论
এ᭄画画的北北2 小时前
力扣-208.实现Trie(前缀树)
算法·leetcode
草莓熊Lotso2 小时前
【数据结构初阶】--排序(四):归并排序
c语言·数据结构·经验分享·其他·算法·排序算法