题目描述
环形链表Ⅱ 给定一个链表,返回链表开始入环的第一个节点。
解答分析
相信很多小伙伴看完官方解答,对利用快慢指针方式去找到相遇点,再把快指针指向起始点,同慢指针匀速前进直到相遇即为入环点感到不可思议,或者产生妙不可言的感受。
那么为什么相遇点到入环点的距离就是起始点到入环点的距离呢?
下面我将利用公式和图形方式推导结果,得出结论(本文是建立在读者已经清楚判断链表是否有环,和能找到相遇点的基础上的,不理解的小伙伴可以先看看官网上的代码解答过程):
1. 第一种情况,链表本身是个大圆环
那么很明白,起始点就在圆上。那么我告诉你,在环里,快慢指针再次相遇的点还是起始点,肯定觉得很疑惑吧,哈哈哈。
如图,假设圆上起始点是a,到最后他们相遇的点是b,设ab的距离是x,圆的周长是y;
慢指针速度是 v s v_s vs,快指针速度是 v f v_f vf,他们运动的次数是 t