题目描述
给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。
为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。 如果 pos 是 -1,则在该链表中没有环。注意,pos 仅仅是用于标识环的情况,并不会作为参数传递到函数中。
说明:不允许修改给定的链表。
思路分析
- 快慢指针,两指针相遇时,慢指针回到开头,快指针从下一个节点开始。
- 两个指针一步一步走,相同时则为入环的第一个节点
- na + b = 2na + b
代码实现
func detectCycle(head *ListNode) *ListNode {
if head == nil {
return nil
}
fast := head.Next
slow := head
for fast != nil && fast.Next != nil {
if fast == slow {
slow = head
fast = fast.Next
for fast != slow {
fast = fast.Next
slow = slow.Next
}
return fast
}
fast = fast.Next.Next
slow = slow.Next
}
return nil
}