环形链表——python

佐手、 提交于 2020-03-10 10:19:17

问题描述

给定一个链表,判断链表中是否有环。

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

示例 :

输入:head = [3,2,0,-4], pos = 1
输出:true
解释:链表中有一个环,其尾部连接到第二个节点。

在这里插入图片描述

双指针法

快慢指针,快指针每走两步慢指针走一步,二者相遇的话说明有环

代码

class Solution:
    def hasCycle(self, head: ListNode) -> bool:
        fast = head
        slow = head
        while fast and slow and fast.next:
            fast = fast.next.next
            slow = slow.next
            if slow == fast:
                return True
        return False

运行结果

在这里插入图片描述
O(1)空间复杂度居然只击败了7%的提交
看了讨论区的大佬们的破坏链表元素和"bjfuvth"做法之后。。。无语.jpg

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!