通过画图,我理解了环形链表Ⅱ

题目描述

环形链表Ⅱ 给定一个链表,返回链表开始入环的第一个节点。

解答分析

相信很多小伙伴看完官方解答,对利用快慢指针方式去找到相遇点,再把快指针指向起始点,同慢指针匀速前进直到相遇即为入环点感到不可思议,或者产生妙不可言的感受。
那么为什么相遇点到入环点的距离就是起始点到入环点的距离呢?
下面我将利用公式和图形方式推导结果,得出结论(本文是建立在读者已经清楚判断链表是否有环,和能找到相遇点的基础上的,不理解的小伙伴可以先看看官网上的代码解答过程):

1. 第一种情况,链表本身是个大圆环

那么很明白,起始点就在圆上。那么我告诉你,在环里,快慢指针再次相遇的点还是起始点,肯定觉得很疑惑吧,哈哈哈。
如图,假设圆上起始点是a,到最后他们相遇的点是b,设ab的距离是x,圆的周长是y;
链表是大圆环
慢指针速度是 v s v_s vs,快指针速度是 v f v_f vf,他们运动的次数是 t

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值