力扣热题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
相关推荐
源代码•宸11 分钟前
Leetcode—620. 有趣的电影&&Q3. 有趣的电影【简单】
数据库·后端·mysql·算法·leetcode·职场和发展
2301_8002561137 分钟前
地理空间数据库中的CPU 和 I/O 开销
数据库·算法·oracle
一个不知名程序员www1 小时前
算法学习入门---结构体和类(C++)
c++·算法
XFF不秃头4 小时前
力扣刷题笔记-旋转图像
c++·笔记·算法·leetcode
王老师青少年编程4 小时前
csp信奥赛C++标准模板库STL案例应用3
c++·算法·stl·csp·信奥赛·lower_bound·标准模版库
有为少年5 小时前
Welford 算法 | 优雅地计算海量数据的均值与方差
人工智能·深度学习·神经网络·学习·算法·机器学习·均值算法
Ven%5 小时前
从单轮问答到连贯对话:RAG多轮对话技术详解
人工智能·python·深度学习·神经网络·算法
山楂树の5 小时前
爬楼梯(动态规划)
算法·动态规划
谈笑也风生5 小时前
经典算法题型之复数乘法(二)
开发语言·python·算法