一、题目解析
给一个链表,若其中包含环,请找出该链表的环的入口结点,否则,输出null。
设置快慢指针,都从链表出发,快指针每次走两步,慢指针每次走一步,假如有环一定会相遇于环中的某点
结论1:两个指针分别从链表头和相遇点继续出发,每次走一步,最后一定相遇与环入口。
证明结论1:设置快慢指针fast和low,fast每次走两步,low每次走一步。假如有环,两者一定会相遇(因为low一旦进环,可看作fast在后面追赶low的过程,每次两者都接近一步,最后一定能追上)。
接着让两个指针分别从相遇点和链表头出发,两者都改为每次走一步,最终相遇于环入口
结论2:两个指针分别从相遇点和链表头出发,两者都改为每次走一步,最终相遇于环入口
链表头到环入口长度为:a
环入口到相遇点长度为:b
相遇点到环入口长度:c