【数据结构】链表专题3

前言

本篇博客我们继续来讨论链表专题,今天的链表算法题是经典中的经典

💓 个人主页:小张同学zkf

⏩ 文章专栏:数据结构

若有问题 评论区见📝

🎉欢迎大家点赞👍收藏⭐文章

目录

1.判断链表是否有环

2.返回入环的第一个节点

3.随机链表的复制


1.判断链表是否有环

这道题链表尾指针很有可能指向链表中任何一个节点,所以是带环的意思,当然尾指针很有可能指向他自己

所以我们分析一下,该怎么判断带有环,有些人直接说我就判断是否和我原来的值相等,相等的话就是代表有环,但这种情况不能确保一定有环,因为即使我没进环也有可能值相等,所以这个行不通,所以我们要判断的话还得需要快慢指针,若快指针追上慢指针代表这链表有环,为什么快指针追上慢指针就会带有环那?

 我们来画图分析一下

slow和fast最初都在头结点, 我们让fast一次走两步,slow一次走一步,假如没换那么fast或fast->next就会指向空,假如有环,那么fast先进环,slow后进环,若fast追上slow就证明了这个链表就带有环

代码如下

这道题曾经被一个面试官提出新的问题

为什么一定会相遇,有没有可能会错过,永远追不上?

我们先来看第一个问题,我们假设slow进环后与fast距离为N, 环的长度是C

那么fast追击slow的过程距离变化如下:

N为偶数                 N为奇数 

N                            N

N-2                         N-2

N-4                         N-4

……                       ……

4                             3

2                            1

0                             -1

可以看出N若为偶数追上了,若N为奇数,则代表fast错过了,需要新的一轮追击,此刻他们之间的距离就变成了C-1,继续追击,我们根据第一轮追击可以得知,C-1是偶数的话代表第二轮追上了,C-1还是奇数的话,又错了一位,距离又变成了C-1,C-1既然是奇数,那就代表永远追不上了

所以追不上的条件前提是,第二轮的C-1是奇数,第一轮的N是奇数,但我们想想这两个条件会不会同时存在

这里我们就需要用到数学列等式的思维来判断两个条件是否可以同时存在

我们假设进环之前的距离是L

那么slow刚进环时,slow走过的距离是L,此刻我们假设fast走了x圈,那fast走过的距离就是L+x*C+C-N

fast的距离是slow的三倍

那么就有了等式

3L=L+x*C+C-N

换算为:2*L=(x+1)*C-N

偶数=(x+1)*偶数-奇数

我们根据数学运算法则中 ,N是奇数时,C必须是奇数,才能使等式成立,N是偶数时,C必须也是偶数,才能使等式成立。

所以,当N是奇数时,C为奇数,C-1为偶数,所以C-1不可能为奇数,所以不可能永远追不上,肯定相遇。                       

结论:一定能追上

N是偶数第一轮就追上了

N是奇数第一轮追不上,第二轮就追上了


2.返回入环的第一个节点

上面那道题是判断是否有环,这道题就是若有环,返回环的第一个节点,所以我们还是需要用到快慢指针,我们画图表示

如图,这里其实有个非常巧妙的方法,我们让慢指针一次走一步,快指针一次走两步,直到环里相遇,再创建两个指针,一个从头开始走,另一个从快慢指针相遇的地方开始走,俩指针一次走一步,这俩指针若相遇,则相遇的点必定是进环的首节点

代码如下

可是为什么那?

我们还是用数学的方法来证明一下 

我们假设,环之前的距离是L,环的长度为C,相遇点与入环点的距离为N,在慢指针进入环点时,快指针走了x圈

那么相遇时,slow走的距离是L+N

fast走的距离是L+x*C+N

fast走的路程是slow两倍

那么就有了等式

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

最后换算成L=(x-1)*C+C-N

假如x=1,那么L=C-N,正好是相遇点到入环首节点的距离与入环之前的距离相等,那么此时在头结点与相遇节点创建俩指针同时走,正好相遇在入环首节点,证实了我们上面的代码想法,但有人会想,你这里假设为1呀,我让它不为一,不唯一的话,相当于在相遇节点的指针多走了几圈C,最后还是在入环首节点相遇。


3.随机链表的复制

这道题链表每个节点里多了个指针指向随机节点,也有可能指向空,然后我们要深拷贝一份(深拷贝意思就是把指针指向对应的值对应关系也要在新拷贝的链表中实现),有人说我直接遍历然后拷贝不就行了,硬拷贝是可以的,但是有个问题,随机指针(random)指向的值如何在新链表中实现,有人说我在新链表里继续找就行呀,但是我们仔细想一下,我们链表里值有可能有时相等,所以如果你先拷贝过去,然后再去找对应的值,可能找到的值不是原链表对应的值,而是值相等的那个位置的节点。

比如就会出现图上这个情况,11找的就不是原来第四位的7,而是第一位的7,这就没拷贝成功。

所以这道题这种做法是不行的

我们先想一下,这道题我们要是先靠拷贝一下,然后插在原节点的后面其拷贝的节点就与源节点有了对应的关联关系

我们画图看一下

这一步代码如下

第二步控制random,拷贝完了,那拷贝那一份链表里的random怎么找那,其实很简单,拷贝的random是不是就是原值的random的next(这一点仔细想想,这一点想明白,这道题就没什么难点了)

第二步代码如下

第三步尾插新链表,将拷贝在原链表的节点尾插新链表,并返回新链表的头结点

代码如下

这道题整体代码如下

相当于三个while嘛,一个while循环一步


结束语 

链表有关算法题也就总结完了,从链表专题1到3都是特别经典的算法题,我们一定要反复练习掌握,OK,感谢观看!!!

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

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

相关文章

ROS1快速入门学习笔记 - 014launch启动文件的使用方法

一、定义 Launch文件&#xff1a;通过XML文件实现多节点的配置和启动&#xff08;可自动启动ROSMaster&#xff09; 二、常用语法 1. 根标签 <launch> - launch文件中的根元素采用<launch>标签定义 <launch>表示开始&#xff1b;<launch>表示结束&…

AD | Altium Designer(原理图设计、电路仿真、PCB绘图)汉化版

Altium Designer(原理图设计、电路仿真、PCB绘图) 通知公告 Altium Designer(AD)是一种功能强大的电子设计自动化(EDA)软件。它主要用于设计和开发电子产品,如电路板(PCB)、集成电路(IC)和嵌入式系统。AD提供了完整的设计工具套件,包括原理图设计、PCB布局、仿真、设…

40.WEB渗透测试-信息收集-域名、指纹收集(2)

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a; 易锦网校会员专享课 上一个内容&#xff1a;39.WEB渗透测试-信息收集-域名、指纹收集&#xff08;1&#xff09; oneforall的安装前置…

基于粒子滤波器的电池剩余使用寿命计算matlab仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 4.1 粒子滤波器基础 4.2 电池剩余使用寿命建模与预测 4.3 粒子滤波器在电池寿命预测中的应用 5.完整工程文件 1.课题概述 基于粒子滤波器的电池剩余使用寿命计算。根据已知的数据&#xff0c;预测未来…

OPPO A72/A55/K7X/A53真我Q3S等手机ROOT刷机后广电卡没信号不读卡解决办法

目前运营商除了移动联通电信以外&#xff0c;还存在1个中国广电&#xff0c;广电属于第四大运营商&#xff0c;由于广电起步较晚&#xff0c;对于手机频段要求也自然不一样&#xff0c;导致目前市面上部分手机出厂没有信号或者不读卡等问题&#xff0c;特别在手机被用户自行刷机…

二叉树的遍历算法

目录 1.二叉树结构 2.广度优先搜索二叉树&#xff08;迭代算法&#xff09; 3.深度优先搜索二叉树&#xff08;递归算法&#xff09; 1.二叉树结构 一个父结点&#xff0c;至多可以连接左右两个子节点 Java构造树结构——其实是 自定义树结点类型 public class TreeNode {in…

信号,信号列表,信号产生方式,信号处理方式

什么是信号 信号在我们的生活中非常常见&#xff1b;如红绿灯&#xff0c;下课铃&#xff0c;游戏团战信号&#xff0c;这些都是信号&#xff1b;信号用来提示接收信号者行动&#xff0c;但接收信号的人接收到信号会进行一系列的行为&#xff0c;完成某个动作&#xff1b;这就…

cmake的使用方法: 多个源文件的编译

一. 简介 前面一篇文章学习了针对只有一个 .c源文件&#xff0c;如何编写 CMakeLists.txt内容&#xff0c;从而使用 cmake工具如何编译工程。文章如下&#xff1a; cmake的使用方法: 单个源文件的编译-CSDN博客 本文学习针对 多个 .c源文件&#xff0c; CMakeLists.txt文件如…

融创共赢,算网领航 | 移动云智能芯片开放实验室正式发布

4月29日上午&#xff0c;中国移动算力网络大会“融创共赢&#xff0c;算网领航-算网原生技术”分论坛在苏州金鸡湖国际会议中心顺利召开&#xff0c;中国移动云能力中心副总经理吴世俊出席论坛并发表致辞。大会举行了智能芯片开放实验室发布仪式&#xff0c;同时发布移动云最新…

CogAgent:开创性的VLM在GUI理解和自动化任务中的突破

尽管LLMs如ChatGPT在撰写电子邮件等任务上能够提供帮助&#xff0c;它们在理解和与GUIs交互方面存在挑战&#xff0c;这限制了它们在提高自动化水平方面的潜力。数字世界中的自主代理是许多现代人梦寐以求的理想助手。这些代理能够根据用户输入的任务描述自动完成如在线预订票务…

【模板】前缀和

原题链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 目录 1. 题目描述 2. 思路分析 3. 代码实现 1. 题目描述 2. 思路分析 前缀和模板题。 前缀和中数组下标为1~n。 前缀和&#xff1a;pre[i]pre[i-1]a[i]; 某段区间 [l,r]的和&#xff1a;pre[r]-pre[l-1] 3.…

android天气实战

页面绘制 问题1、下拉框需要背景为透明 我懒得写全部省份就写了5个所以不需要往下 图标准备 iconfont-阿里巴巴矢量图标库几坤年没来这了好怀念啊&#xff0c;图标库选择下雨的图标等 准备网络请求 0、API接口准备 api免费七日天气接口API 未来一周天气预报api (tianqiap…

前端业务开发中使用原生js和elementui两种方式实现头像裁切上传的功能

日常业务开发中&#xff0c;无论是后台管理系统还是前台界面&#xff0c;都会遇到图片裁剪的业务需求&#xff0c;选择合适的尺寸或者图片的关键部分&#xff0c;满足我们的功能需求&#xff01;&#xff01; 效果预览 效果一&#xff1a; 效果二: 实现过程 1.原生js实现方…

VS(Visual Studio)中查找项目里的中文字符

目录 正则表达式查找中文字符 正则表达式查找中文字符 在Visual Studio (VS) 中查找所有的中文字符&#xff0c;你可以使用其强大的查找和替换功能。不过&#xff0c;由于中文字符的范围非常广泛&#xff08;包括简体中文、繁体中文、日本汉字、韩国汉字等&#xff09;&#xf…

GPT3 终极指南(一)

原文&#xff1a;zh.annas-archive.org/md5/6de8906c86a2711a5a84c839bec7e073 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 前言 GPT-3&#xff0c;或者说是 Generative Pre-trained Transformer 3&#xff0c;是由 OpenAI 开发的基于 Transformer 的大型语言模型…

平安城市 校园 景区 停车场网络语音对讲立柱SV-11TS

平安城市 校园 景区 停车场网络语音对讲立柱SV-11TS 长方形立柱式设计&#xff0c;外观简约&#xff0c;线条优美&#xff0c;工艺考究&#xff0c;坚固耐用可一键实现在紧急情况下求助报警、事件咨询&#xff0c;与SIP网络对讲主机进行全双工对讲。内置警示灯&#xff0c;呼叫…

iOS ------ Method Swizzling (动态方法交换)

一&#xff0c;Method Swizzling 简介 Method&#xff08;方法&#xff09;对应的是objc_method结构体&#xff1b;而objc_method结构体中包含了SEL method_name(方法名&#xff09;&#xff0c;IMP method_imp&#xff08;方法实现&#xff09; // objc_method 结构体 typed…

Linux下启动jenkins报错问题解决

jenkins端口报错 java.io.IOException: Failed to start Jettyat winstone.Launcher.<init>(Launcher.java:209)at winstone.Launcher.main(Launcher.java:496)at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)at java.base/jdk.int…

【题目】2023年全国职业院校技能大赛 GZ073 网络系统管理赛项赛题第3套A模块

2023年全国职业院校技能大赛 GZ073网络系统管理赛项 赛题第3套 信息安全管理与评估 网络系统管理 网络搭建与应用 云计算 软件测试 移动应用开发等多个赛项技术支持 任务书&#xff0c;赛题&#xff0c;解析等资料&#xff0c;知识点培训服务 添加博主wx&#xff1a;liuliu54…

全国产化BMC子卡详细介绍

一款基于全国产的BMC子卡&#xff0c;可实现ChMC/IPMC功能。子卡遵循IPMI 1.5/2.0协议规范&#xff0c;也支持客制OEM命令。子卡可获取载板板卡环境信息&#xff0c;板卡属性信息和板卡状态信息等&#xff0c;其中包括温度、电压、电流等信息&#xff1b;FRU、系统版本、CPU型号…