題目:
思路:利用兩個指針對鍊錶進行遍歷,如果兩指標指向同乙個節點時,令fast=head,然後重新進行遍歷,再次相遇時的節點即為環的起點。
**:
#definition for singly-linked list.
#class listnode:
#def __init__(self, x):
#self.val = x
#self.next = none
class
solution:
def detectcycle(self, head: listnode) ->listnode:
fast, slow =head, head
while
true:
if (fast==none or fast.next==none): return
fast, slow =fast.next.next, slow.next
if fast == slow: break
#相遇即要跳出
fast =head
while fast!=slow :#
從頭開始走
fast =fast.next
slow =slow.next
return slow
142 環形鍊錶 II
還是快慢指標的問題,當發現有環時,將fast指向head,fast一次向前移動乙個節點,則fast和slow一定會在環的入口相遇.證明 設s為slow指標走的節點個數,m為環的入口距head的位置 則第一次相遇時,fast和head相對於環入口的位置相同,fast在環中的相對於環入口的位置在 2s ...
142 環形鍊錶 II
給定乙個鍊錶,返回鍊錶開始入環的第乙個節點。如果鍊錶無環,則返回null。說明 不允許修改給定的鍊錶。高階 你是否可以不用額外空間解決此題?definition for singly linked list.struct listnode class solution node set.insert...
142 環形鍊錶 II
給定乙個鍊錶,返回鍊錶開始入環的第乙個節點。如果鍊錶無環,則返回 null。為了表示給定鍊錶中的環,我們使用整數 pos 來表示鍊錶尾連線到鍊錶中的位置 索引從 0 開始 如果 pos 是 1,則在該鍊錶中沒有環。說明 不允許修改給定的鍊錶。示例 1 輸入 head 3,2,0,4 pos 1 輸出...