环形链表的判定与其拓展延伸---LeetCode OJ题详解
创始人
2024-06-02 02:25:24
0

Alt

💓问题:

给你一个链表的头节点 head ,判断链表中是否有环。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。
为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。

如果链表中存在环 ,则返回 true 。 否则,返回 false 。

来源:力扣(LeetCode)

图解:

在这里插入图片描述

代码展示:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/
bool hasCycle(struct ListNode *head) {struct ListNode* fast=head;struct ListNode* slow=head;while(fast&&fast->next){fast=fast->next->next;slow=slow->next;if(slow==fast)return true;}return false;
}

拓展延伸:

其实这就像是 高中物理题 的追击相遇问题

和两个指针之间的距离与每回两个指针之间缩减的距离密切相关。

那会有同学想怎么确定fast 一定会追上slow 指针呢,他两个一定会在环里相遇呢?
其实这是一个推理证明题,
我们先来看结论

slow走一步 ,fast 走两步 fast 一定会追上slow

我们简单来推理一下
当slow 也进入环之后,fast 也就开始追了。 假设一下,这时候两个指针之间的距离是N
再追的过程·当中,两个指针的距离每次都会缩小一
N
N-1
N-2
N-3
… …
3
2
1
0
当距离N为0 的时候就会追上了。所以一定就会追上。

那么当slow 走一步,fast 走三步 会不会·追上·呢?

假设两个指针之间距离还是N,每回两者之间的距离会减少2 ,所以
N
N-2
N-4
N-6
… …
最后不一定会是0;
有可能会是一个负数, 那么当出现负数的时候就证明已经错过了。
在这里插入图片描述
如此图所示:

slow与fast 之间的距离为5 ,也就是N=5
每次两个指针之间的距离减2 最后成-1了
也就是下面图所示,fast 把slow 超过去了,两个指针并不相等。

在这里插入图片描述
所以就会继续进行指针移动,直到有一天 ,两个指针正好指向了同一个位置,相等了才会停下来。

要不然就是一个死循环,一直不会结束。

所以得到结论:

当slow 走一步,fast 走三步 ,不确定,有可能会追上正好相等,也有可能是一个死循环。

那么同理就可以证明slow 走一步,fast 走四步的 时候呢?

有兴趣的同学可以自行研究一下。

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...