码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 链表有环,快慢指针走3步可以吗


    先说结果,可以走三步,但没必要,反而会影响效率。

    下面是推导过程,摘自stackflow。
    在这里插入图片描述
    设非环的部分s步,环t步,快指针速度是慢指针的k倍,快慢指针在距离环开头的 j 步处相遇。

    那么,相遇时,慢指针走了s+j,快指针走了s + j + m * t,(m是快指针在环中的圈数)

    此时,快指针走的距离时慢指针的k倍,则有等式:

    k * (s + j) = s + j + m * t
    
    • 1

    变换一下:

    s + j =  (m / k-1)t
    
    • 1

    根据上面的公式可知,等式左边是慢指针走的步数,是等式右边环长度的倍数,慢指针步数s + j是整数,环长度t也是整数,(m / k-1)中,k-1>0,在其他量都确定的情况下,保持(m / k-1)不变的话,分母k-1越小,则分子m也越小,对应快指针在环中走的圈数m也越小,k=2,3,4···,其中k=2时,m最小,即最快相遇,这样效率最高。

    环形链表入环点

    leetcode142题:https://leetcode.cn/problems/linked-list-cycle-ii/
    同样可以推导一下。
    快慢指针走得步数:f=2(s+j)
    快慢指针相遇时,f=(s+j) +mt(公式含义同最上)
    则可以得出s+j=mt,相遇时绕的圈数刚好等于慢指针走的步数。
    假设此时再走 l 步到达环的入口,会与走s步的指针相遇,有mt+l=mt+s (环中加mt还是原点)
    合并上面两个式子后得 l=s,即再走非环的部分s步即可到入环点。

    如图,紫色节点相遇后,假设快指针再绕一圈到这里,走了b+c,而慢指针走到这里,走了a+b,其中b为公共部分,则a=c。
    在这里插入图片描述

    总结:相遇时,慢指针走的步数刚好为快指针在环中绕圈的总步数,距离入环点的步数刚好是非环路径步数。

    参考链接:https://stackoverflow.com/questions/5130246/why-increase-pointer-by-two-while-finding-loop-in-linked-list-why-not-3-4-5

  • 相关阅读:
    【交通建模】基于模型的自主交通仿真框架附matlab代码
    Notion 又一开源替代品,诞生了!
    200、使用默认 Exchange 实现 P2P 消息 之 消息生产者(发送消息) 和 消息消费者(消费消息)
    竞赛 基于深度学的图像修复 图像补全
    前端两个重点:性能优化、安全
    Tools_Download
    这些 JavaScript 笔试题你能答对几道?
    掉电安全文件系统littlefs移植
    媲美有线操作,支持4KHz响应和无线充电的游戏鼠标,雷柏VT3S上手
    MySQL 8.0 OCP 1Z0-908认证考试题库(7-20)
  • 原文地址:https://blog.csdn.net/weixin_44139651/article/details/125427418
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号