给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。
1.把见过的节点丢集合里,下次再遇见就是环的开始:
def detectCycle(self, head):
"""
:type head: ListNode
:rtype: ListNode
"""
s={None}
while head not in s:
s.add(head)
head=head.next
return head
2.快慢指针法:
设环的起始节点为 E,快慢指针从 head 出发,快指针速度为 2,设相交节点为 X,head 到 E 的距离为 H,E 到 X 的距离为 D,环的长度为 L,那么有:快指针走过的距离等于慢指针走过的距离加快指针多走的距离(多走了 n 圈的 L) 2(H + D) = H + D + nL,因此可以推出 H = nL - D,这意味着如果我们让俩个慢指针一个从 head 出发,一个从 X 出发的话,他们一定会在节点 E 相遇
def detectCycle(self, head):
"""
:type head: ListNode
:rtype: ListNode
"""
fast=slow=head
while fast and fast.next:
fast=fast.next.next
slow=slow.next
if fast == slow:
break
else:
return None
while head is not slow:
head=head.next
slow=slow.next
return head