1.题目
给定一个链表,如果链表中存在环,则返回到链表中环的起始节点的值,如果没有环,返回null。
给出 -21->10->4->5, tail connects to node index 1,返回10
2.算法
当我们找到两个指针相遇的点时
t = X+nY+K
2t = X+mY+K
2X + 2nY + 2K = X + mY + K
X+K = (m-2n)Y
上式表示的是,当在走x步的时候,就走了环的倍数
public ListNode detectCycle(ListNode head)
{
// write your code here
ListNode slow = head;
ListNode fast = head;
while(fast != null && fast.next != null){
slow = slow.next;
fast = fast.next.next;
if(slow == fast)
break;
}
if(fast == null || fast.next == null)
return null;
slow = head;
while(slow != fast){
slow = slow.next;
fast = fast.next;
}
return fast;
}