码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 快慢指针的几种应用场景,你真的了解吗?


    1、基本原理

    快慢指针方法,又称为龟兔赛跑算法,其基本思想就是使用两个移动速度不同的指针(快指针是慢指针的X倍,X > 1)在数组或链表等序列结构上移动,移动的速度一快一慢,以此来制造出自己想要的差值。这个差值可以让我们找到链表上相应的节点。

    2、应用场景

    (1)寻找中间值
    思路分析:

    一般的思路是:先遍历一次链表,记录住一共有多少个节点,然后,再次遍历找寻中点。

    利用快慢指针的思路是:我们把一个链表看成一个跑道,假设 a 的速度是 b 的两倍,那么当 a 跑完全程后,b 刚好跑一半,以此来达到找到中间节点的目的。

    第一步:slow 与 fast 指针都指向链表第一个节点,然后 slow 每次移动一个指针,fast 每次移动两个指针。

    在这里插入图片描述

    第二步:使用两个指针遍历链表,当快指针指向的结点没有下一个结点了,就可以结束了,结束之后,慢指针指向的结点就是中间值

    代码实现:

    第一步:先定义一段代码

  • 相关阅读:
    解决pycharm每次新建项目都要重新pip安装一些第三方库等问题
    量化风控的贷前实操课—详解的规则调优
    给定一个二进制数组,计算其中最大连续1的个数
    高德地图设置电子围栏
    图像融合--挑战、机遇与对策
    面试官:线程池中多余的线程是如何回收的?
    Servlet的生命周期
    JS中应优先书写函数声明还是函数表达式?
    PingCode 完成近亿元人民币C轮融资,打造世界级研发管理与协作平台
    c++ std::cout输出结果错误,只有一堆数字没有指定的字符串?
  • 原文地址:https://blog.csdn.net/hcz666/article/details/126699143
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号