题目如下:
Given a linked list, return the node where the cycle begins. If there is no cycle, return null.
Follow up:
Can you solve it without using extra space?
题目分析:
本题是上一道题目的扩展。可以沿用上一题目的方式。使用一块一慢两个指针从起点开始行走。快指针每次走2步,慢指针每次走1步。如果链表中有环,2者必然会在环中某点相遇。
假设链表恰好是尾巴指向了开头,即假设链表恰好从头道尾都是一个环。那么相遇点必然在两个指针开始走动的起点。
假设链表的组成为先有一段单链表后有一个环,那么相遇点显然不一定是起点了,相遇点显然也和之前那段单链表的长度是相关的。
具体的数学关系可以通过推导得知,参考了这篇博客,如下。
1 设链表长度为len(链表中非空next指针的个数,下面所说的长度均为非空next指针的个数),链表head到环的起点长度为a,环起点到快慢指针相遇点的长度为b,环的长度为r。
2 假设到快慢指针相遇时,慢指针移动的长度为s,则快指针移动长度为2s,而快指针移动的长度还等于s加上在环上绕的k圈(k>=1),所以2s=s+kr ,即s = kr。
3 由s = a + b 和 s = kr 可知 a + b