龟兔赛跑,环形链表解题思路:用兔子的速度,龟的智慧,和链表的结构,解决力扣难题

news2025/1/20 1:44:12

在这里插入图片描述

本篇博客会讲解力扣“141. 环形链表”的解题思路,这是题目链接。

审题

先来审题:
在这里插入图片描述
以下是输出示例:
在这里插入图片描述
以下是提示:
在这里插入图片描述
以下是进阶:
在这里插入图片描述

思路

本题有一种非常巧妙的解法:快慢指针法,又称龟兔赛跑法。思路如下:

定义一个快指针,从头结点开始,每次走2步;定义一个慢指针,从头结点开始,每次走1步。接下来分2种情况:

  1. 没有环:快指针会跑在前面,率先走到链表尾部。
  2. 有环:快慢指针先后进环,在环里跑圈,快指针会追上慢指针。

代码

我先写代码,再来证明以上说法的合理性。

bool hasCycle(struct ListNode *head) {
    // 定义快慢指针
    struct ListNode* fast = head;
    struct ListNode* slow = head;
    // 龟兔赛跑
    while (fast && fast->next)
    {
        // slow一次走1步
        slow = slow->next;
        // fast一次走2步
        fast = fast->next->next;
        // 若fast追上了slow,说明有环
        if (slow == fast)
            return true;
    }

    // fast走到了链表尾,说明没有环
    return false;
}

在这里插入图片描述
轻松通过。

证明

接下来有2个问题:

  1. 当链表中存在环时,为什么快指针一次走2步,慢指针一次走1步,快指针一定会追上慢指针?
  2. 如果快指针一次走3步,慢指针一次走1步,快指针是否一定能追上慢指针呢?

先来回答第一个问题。我们来模拟以下过程:假设链表中存在环,快指针会先进环,慢指针会后进环,接着快指针开始追击慢指针。

假设快指针和慢指针之间差了n个结点,由于每次追击,快指针都会比慢指针多走1步,每次距离会缩小1,它们之间的距离就会如下变化:

n
n-1
n-2
...
3
2
1
0

当距离减到0时,快指针就追上了慢指针。由于每次距离都会缩小1,2个指针不会错过,一定能追上。

接着回答第二个问题:还是假设链表有环,快指针先进环,慢指针后进环,开始追击。假设此时快慢指针的距离为n,每次追击,快指针会比慢指针多走2步,它们之间的距离变化就是:

n
n-2
n-4
...

此时就分为2种情况,n为偶数时:

n
n-2
n-4
...
4
2
0

2个指针的距离会缩小到0,能够追上。但是若n为奇数呢?

n
n-2
n-4
...
5
3
1
-1
...

这个-1代表了,快指针错过了慢指针,跑到慢指针前面了。假设环的长度是c,那么此时快慢指针的距离就是c-1。此时又分2种情况,若c-1为偶数,那么就能够追上;若c-1为奇数,又会错过,距离变成-1,看做c-1,而c-1还是奇数,周而复始,每次都会错过,就永远追不上了。

所以,若快指针一次走3步,慢指针一次走1步,若链表中存在环,当快慢指针都进环时的距离为n,环的周长为c时,分为3种情况:

  1. n为偶数,能够追上。
  2. n为奇数,但c-1为偶数,能够追上。
  3. n为奇数,n-1也是奇数,永远追不上。

总结

  1. 链表中是否带环的判断,可以使用快慢指针法,形象的说法是龟兔赛跑法。
  2. 快指针一次走2步,慢指针一次走1步,若带环,一定能够追上。快指针一次走3步,慢指针一次走1步,若带环,不一定能追上。

感谢大家的阅读!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/523150.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot——默认页面在哪里?

简单介绍: 在之前我们创建了一个SpringBoot的应用程序,并且我们也启动了,但是我们都是在postman或者是在控制台看到了我们的界面,那么在浏览器中看到的界面其实只有一个: 这个界面其实就是SpringBoot的报错默认界面&a…

buuctf8

目录 crypto 摩丝 password 变异凯撒 Quoted-printable Rabbit web [护网杯 2018]easy_tornado [HCTF 2018]admin misc 被劫持的神秘礼物​编辑 crypto 摩丝 下载文件,得到一串摩斯密码 在线解码 password 下载文件 张三英文zs,加上生日&a…

opencv_contrib模块编译与安装

前言 由于opencv_contrib模块的安装依赖于opencv基础模块,所以看该教程前请先看一遍OpenCV基础模块安装教程 下载 下载 opencv_contrib模块(需要与opencv基础模块版本号4.6.0相同,国内可以在gitcode下载) 配置、编译、安装 打…

网工视角看基础网络,原来这么与众不同

大家好,我是老杨。 前两天去华为生态大会刚回来,颇为感慨。 感慨万物互联的世界越来越大,网络渗透度也越来越极致化。 网络很大,非常大,但在网工眼里,网络复杂又美妙,有着外行人难以理解的魅…

大数据Doris(十九):Doris索引介绍与前缀索引

文章目录 Doris索引介绍与前缀索引 一、Doris索引介绍 二、前缀索引 Doris索引介绍与前缀索引 一、Doris索引介绍 索引用于帮助快速过滤或查找数据。目前 Doris 主要支持两类索引: 内建的智能索引,包括前缀索引和 ZoneMap

【Prompting】ChatGPT Prompt Engineering开发指南(2)

ChatGPT Prompt Engineering开发指南2 从产品概况表生成营销产品描述问题1:文本太长问题2: 文本聚焦于错误的细节问题3:描述需要一个尺寸表 加载Python库查看HTML内容来源 在本教程中,学习迭代分析并完善给出的提示,以从结果概况表…

20230514 Google宣布引入生成式人工智能搜索引擎

🚀 Google宣布引入生成式人工智能搜索引擎,可能是最大变化之一。 Google宣布引入生成式人工智能搜索引擎,可能是最大变化之一。 新搜索将使用人工智能模型整合互联网信息,更好地响应用户需求。然而,网络出版商担心这…

python+vue流浪动物公益科普宠物在线领养网站

使用动物在线领养网站的用户分管理员和用户两个角色的权限子模块。 开发语言:Python 框架:django/flask Python版本:python3.7.7 数据库:mysql 数据库工具:Navicat 开发软件:PyCharm 系统所要实现的功…

接口自动化测试之request模块讲解,以及初步接口自动化测试框架封装(统一请求)

一、有接口测试工具的情况下,为什么要做接口自动化? 1.敏捷开发,接口一般数量很大,团队实现接测试,版本控制。 2.功能太死板,有些接口完全无法实现(复杂的加密接口,签名接口等) 3.接…

【STL十九】算法——修改序列的操作(copy、move、remove、transform、replace)

算法——不修改序列的操作(copy、move、transform、remove、replace) 一、分类二、修改序列的操作三、copy四、move五、remove、remove_if六、fill、transform、replace、replace_if、reverse 一、分类 根据网站https://www.apiref.com/cpp-zh/cpp/head…

Spring的执行流程以及Bean的作用域和生命周期

深入Bean对象 1. Bean对象的作用域1.1 引出作用域问题1.2 六种作用域 2. Spring的执行流程3. Bean对象的生命周期 在之前的学习中,我们了解到Spring能够用来帮助我们管理Java中的Bean对象,我们能够向Spring的IOC容器中添加以及获取对象。那我们从Spring对…

【腾讯云 Finops Crane 集训营】学习云原生成本优化

目录 开篇介绍搭建环境第一步第二步第三步 添加集群成本洞察成本分析资源推荐与副本数智能预测与自动扩缩容EHPA安装Metrics Server创建测试应用创建 EffectiveHPA增加负载整体流程 调度优化负载感知调度拓扑感知调度 混部清理环境 开篇 某次闲逛CSDN,发现了这样一…

(文章复现)基于电力系统碳排放流理论的碳排放分摊模型研究(含matlab代码)

参考文献:基于电力系统碳排放流理论的碳排放分摊模型研究 之前写过一篇博客复现论文《电力系统碳排放流的计算方法初探》,那篇文章模型比较简单,没有考虑网损。(文章复现)电力系统碳排放流的计算方法初探(含matlab代码) 今天要复现的这篇文献…

1行命令本地部署 AgentGPT

本地部署 AgentGPT 部署 AgentGPT访问 AgentGPT 部署 AgentGPT 运行下面命令部署 AgentGPT,输入你的 OpenAI Key, git clone https://github.com/reworkd/AgentGPT.git; cd AgentGPT; ./setup.sh --docker访问 AgentGPT 使用浏览器打开 http://localh…

万得后端一面

目录 1.说说重载和重写2.内连接和外连接3.如果有一个任务来了,线程池怎么运行5.hashset怎么判断重复6.list和set说说7.说说有哪些list8.单例模式的饿汉式和懒汉式,怎么样可以防止反射。9.volatile关键字说说 1.说说重载和重写 1、重载发生在本类&#x…

MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”

MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes” 问题描述 数据库RDS MySQL版在创建表索引时,出现如下错误信息。 Error 1071: Specified key was too long; max key length is 767 bytes.ERROR 1709 (HY000): Index column siz…

基于ESP32/ESP8266的单通道LoRaWAN网关设计-网页界面介绍

资料下载链接》》 网页界面介绍 对于单通道网关的第六版用户界面,我们专注于 Web 界面。本文档仅涉及 Web 界面。有几个部分要讨论: 用户界面说明web界面可以设置哪些参数单通道接口配置涉及的文件。 Web 界面的各个部分 启动 Web 界面时&#xff0…

【评测】腾讯云服务器的性能怎么样?

转载请注明出处:小锋学长生活大爆炸[ http://xfxuezhang.cn] 最近腾讯云推出了5年款服务器,性价比非常的高。但这么便宜的服务器,性能怎么样呢?学长特地领取了新人试用版测试了一下性能,这里与大家分享一下。 服务器领…

与对应负数同时存在的最大正整数

一、2441. 与对应负数同时存在的最大正整数 思路 这个题我想的是将数组中的负数全部找出来放进另一数组,然后再将原数组的元素与与之相比,如果相加等于0,那么就使num; 代码实现 int findMaxK(int* nums, int numsSize){int max0…

学系统集成项目管理工程师(中项)系列21b_整体管理(下)

1. 监控项目工作 1.1. 跟踪、审查和报告项目进展,以实现项目管理计划中确定的绩效目标的过程 1.2. 输入 1.2.1. 项目管理计划 1.2.2. 进度预测 1.2.2.1. 基于实际进展与进度基准的比较而计算出进度预测 1.2.2.1.1. 完工尚需时间估算(ETC) 1.2.2.1.2. 进度偏差(SV…