当前位置: 首页 > news >正文

c语言的数据结构:找环状链表入口处

一起<( ̄︶ ̄)↗[GO!]

1.如何判断一个链表是否有环

思路:设定两个快慢指针fast和slow,fast每次走两个结点,slow每次走一个节点

如果fast指针遇到了Null,那么这个链表没有环,如果fast和slow可以相遇,则代表这个链表有环

代码如下

N:fast先进环,slow后进环,fast和slow之间的距离是N

N--->偶数--->奇数

          N           N

          N-2       N-2

         N-4        N-4

         ...             ...

           4              3

           2              1

           0              -1

       追上了           过了,进入下一个循环(fast超过slow1个结点了)

                             C:圆环的周长 

                             slow和fast之距变为c-1

                             c-1是偶数,下一轮便追上了

                             c-1是奇数,那么永远也追不上

2.找环的入口点

追上相遇时

1.slow所走距离:L+X

2.fast所走距离:L+X+N*C

3.追上之后相关结论推导

2(L+X)= L+X+N*C

为何是2*slow距离=fast之距离?

答:等式两边的表达式实际上是二者所走过的距离.由物理公式X=VT可知,因为是同时运行,时间(循环次数)相同,所以"T"可以约掉,仅有2*Vfast=Vslow;

L+X=N*C      L=N*C-X;

有 L=(N-1)*C+C-X;

得出重要结论:一指针从链表头开始走,

另一指针从相遇点开始走,

则牠们会在入口点相遇

3.代码

思路:1. 先判断是否有环

        2.再让slow和fast相遇,以找到meet点

        3.让head和meet以每循环1结点的速度同向运动,二者相遇之时便是找到入口点之时

http://www.lryc.cn/news/305922.html

相关文章:

  • LabVIEW声速测定实验数据处理
  • 深入剖析C语言中的段错误:从内存模型到实战调试全方位解析
  • 1.操作Python入门Python安装和使用教程
  • STM32G030C8T6:定时器1ms中断(以64MHz外部晶振为例)
  • 人工智能聊天机器人如何帮助您实现工作与生活的平衡
  • 3分钟看懂设计模式01:策略模式
  • 数据结构与算法:算法详解
  • AOSP10 替换系统launcher
  • 视频互动游戏如何暴打海王和舔狗
  • 大学生多媒体课程学习网站thinkphp+vue
  • 信息系统项目管理师论文分享(质量管理)
  • Redis实现滑动窗口限流
  • SQL Server查询计划(Query Plan)——XML查询计划
  • 【day02】每天三道 java后端面试题:Java、C++和Go的区别 | Redis的特点和应用场景 | 计算机网络七层模型
  • 【Flink状态管理(八)】Checkpoint:CheckpointBarrier对齐后Checkpoint的完成、通知与对学习状态管理源码的思考
  • 防御保护第八、九、十、十一天笔记
  • 【TypeScript基础知识点】的讲解
  • 牛客周赛 Round 34 解题报告 | 珂学家 | 构造思维 + 置换环
  • LeetCode13 罗马数字转整数
  • 【Hudi】Upsert原理
  • 信息系统服务:演绎数字时代的征程
  • rust连接postgresql数据库
  • [面试] 什么是死锁? 如何解决死锁?
  • 网络原理 HTTP _ HTTPS
  • 软件实际应用实例,茶楼收银软件管理系统操作流程,茶室计时计费会员管理系统软件试用版教程
  • 网络安全“三保一评”深度解析
  • IDA使用-2023CICSN华中赛区pwn题逆向为例
  • 安装虚拟机出现的一些问题
  • Git+py+ipynb Usage
  • eBPF实践篇之环境搭建