leetcode刷题5:找出链表中环的位置

该博客介绍了如何在单链表中检测环的存在,并找到环的起始节点。通过设置快慢指针,当它们相遇时计算环的长度,然后使用双指针策略确定环的起始位置。提供了一个Python实现的Solution类,包含detectCycle方法来解决这个问题。
摘要由CSDN通过智能技术生成

和上个题类似:给定一个单链表,找出环开始的节点。

使用上一个题目的算法可以判断出当前链表有没有环。


观察1:

如果在快慢指针相遇后,我们继续向前移动慢指针,直到再次相遇,就可以计算出环的长度。

观察2:

使用一个指针遍历链表时,从环开始,经过环的长度次前进,指针会重新指向环开始的位置(从观察1可以很快得出)

观察3:

如果使用两个指针一前一后,假设环的长度为n,前面的指针前进n步之后,后面指针开始前进,则两个指针再次相遇的时候,就是环开始的位置。


综上,根据之前题目的算法可以得到代码:

class Solution:
    def detectCycle(self,head):
        if head == None:
            return None
        if head.next == None:
            return None
        if head.next == head:
            return head


        fast = head.next.next
        slow = head.next


        while fa

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值