给定一个链表,判断链表中是否有环。
进阶:
你能否不使用额外空间解决此题?
python3代码
# Definition for singly-linked list.
# class ListNode(object):
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution(object):
def hasCycle(self, head):
"""
:type head: ListNode
:rtype: bool
"""
if not head:
return False
p1=p2=head#p1每次跑1步,p2每次跑2步
while p2.next and p2.next.next:#判断跑得快的是否为空
p1=p1.next
p2=p2.next.next
if p1==p2:#存在环则必然会出现相等
return True
return False
本文介绍了一种不使用额外空间来判断链表是否存在环的方法。通过快慢指针技巧,一个指针每次移动一步,另一个指针每次移动两步,如果链表中有环,则快慢指针最终会相遇。
499

被折叠的 条评论
为什么被折叠?



