数据结构初阶--链表OJⅡ
目录
- 前言
- 相交链表
- 思路分析
- 代码实现
- 环形链表
- 思路分析
- 代码实现
- 环形链表Ⅱ
- 思路分析
- 代码实现
- 复制带随机指针的链表
- 思路分析
- 代码实现
前言
本篇文章承接上篇博客,继续对部分经典链表OJ题进行讲解
相交链表
先来看题目描述

思路分析
这道题我们还是首先来判断一下链表是否相交,即看两条链表的最后一个节点是否为同一个。如果不相交,则返回空,如果相交,则进行下一步。
如果两条链表相交,我们可以考虑让较长的链表走它们的长度差步,使得两条链表此时的长度一样,然后再同时走直到两条链表的节点指向同一块区域,这个节点就是相交点。
代码实现
代码实现如下
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {struct ListNode* tailA=headA;int lenA=0;struct ListNode* tailB=headB;int lenB=0;while(tailA){tailA=tailA->next;lenA++;}while(tailB){tailB=tailB->next;lenB++;}if(tailA!=tailB){return NULL;}int tmp=abs(lenA-lenB);struct ListNode* llisthead=lenA>lenB?headA:headB;struct ListNode* slisthead=lenA>lenB?headB:headA;while(tmp--){llisthead=llisthead->next;}while(1){if(llisthead==slisthead){break;}llisthead=llisthead->next;slisthead=slisthead->next;}return llisthead;}
环形链表
先来看题

思路分析
这道题我们采用快慢指针的思路,这样如果是环形链表,当快指针和慢指针都进入环时,快指针总能与慢指针遇到,为保证效率和可实现度,我们让快指针一次走两步,慢指针一次走一步。 如果快指针指向空且快指针的下一个节点也指向空(因为要保证快指针能一次走两步),说明该链表并没有形成环。
代码实现
代码如下
bool hasCycle(struct ListNode *head) {if(head==NULL)return false;struct ListNode* slow=head;struct ListNode* fast=head;while(fast&&slow&&fast->next){slow=slow->next;fast=fast->next->next;if(slow==fast)return true;}return false;
}
环形链表Ⅱ
这道题是上一道题的变式,也借鉴了上一题的思路。
来看题

思路分析
我们还是按照上一题的解题思路判断链表是否形成了环。如果没有则返回空,如果是环形链表我们继续进行下一步。
在确定存在环时,此时快指针和慢指针正好相遇,实际上,此时头节点到链表进入环的节点的距离和此时快/慢指针到链表进入环的结点的距离相等。所以此时我们只需要让头指针和快/慢指针同时走到相遇时,即为我们要找的节点。
代码实现
代码实现如下
struct ListNode *detectCycle(struct ListNode *head) {struct ListNode* slow=head;struct ListNode* fast=head;while(fast&&fast->next){slow=slow->next;fast=fast->next->next;if(fast==slow){while(slow!=head){slow=slow->next;head=head->next;}return head;}}return NULL;}
复制带随机指针的链表

思路分析
这道题的本意是让我们复制一次这个链表,我们这里采用的思路是就在原有的链表上操作,1,先在每一个节点后复制一个一样的节点,2,再把所有复制出来的节点与原链表断开,3,再链接起来,这样我们就可以得到一个和原链表一摸一样的新链表了,虽然思路听起来很简单,但是想要真正弄清楚里面所有指针到底该指向哪里,同时又要避免野指针的情况出现,还是非常有难度的,下面我把操作分为三部分来讲解。
-
在每一个节点后复制一个一模一样的节点链接起来
首先我们可以先判断一下链表是否为空,如果为空,就直接返回空指针,否则我们按下图进行操作:(以三个节点为例)


-
把所有复制出来的节点有原链表断开

-
最后将复制出来的节点连接再一次即可。

代码实现
代码实现如下
struct Node* copyRandomList(struct Node* head) {if(head==NULL){return NULL;}for(struct Node* cur=head;cur!=NULL;cur=cur->next->next){struct Node* newnode=(struct Node*)malloc(sizeof(struct Node));newnode->val=cur->val;newnode->next=cur->next;cur->next=newnode;}for(struct Node* cur=head;cur!=NULL;cur=cur->next->next){struct Node* newnode=cur->next;newnode->random=(cur->random!=NULL)?cur->random->next:NULL;}struct Node* newhead=head->next;for(struct Node* cur=head;cur!=NULL;cur=cur->next){struct Node* newnode=cur->next;cur->next=cur->next->next;newnode->next=(newnode->next!=NULL)?newnode->next->next:NULL;}return newhead;
}
以上就是本章全部内容,如有出入,欢迎大佬指正。
相关文章:
数据结构初阶--链表OJⅡ
目录 前言相交链表思路分析代码实现 环形链表思路分析代码实现 环形链表Ⅱ思路分析代码实现 复制带随机指针的链表思路分析代码实现 前言 本篇文章承接上篇博客,继续对部分经典链表OJ题进行讲解 相交链表 先来看题目描述 思路分析 这道题我们还是首先来判断一…...
离职or苟住?
面对不太好的大环境,我们什么时候该离职,什么时候不应该离职呢?分享几个观点,希望对你有所启发。 以前就有大佬讲过,离职无非是两个原因,一是因为薪资不到位,二是因为受委屈了,总之&…...
微服务之以nacos注册中心,以gateway路由转发服务调用实例(第一篇)
实现以nacos为注册中心,网关路由转发调用 项目版本汇总项目初始化新建仓库拉取仓库项目父工程pom初始化依赖版本选择pom文件如下 网关服务构建pom文件启动类配置文件YMLnacos启动新建命名空间配置网关yml(nacos)网关服务启动 用户服务构建pom文件启动类配置文件YML新增url接口配…...
主成分分析(PCA)直观理解与数学推导
近期在完成信息论的作业,发现网上的资料大多是直观解释,对其中的数学原理介绍甚少,并且只介绍了向量降维,而没有介绍向量重构的问题(重构指的是:根据降维后的低维向量来恢复原始向量)࿰…...
什么是合伙企业?普通合伙和有限合伙区别?
1.什么是合伙企业? 合伙企业是指由各合伙人订立合伙协议,共同出资,共同经营,共享收益,共担风险,并对企业债务承担无限连带责任的营利性组织。合伙企业一般无法人资格,不缴纳企业所得税,缴纳个…...
系统结构考点之不明白的点
系统结构考点系列 计算机系统结构的定义计算机组成的定义计算机实现的定义计算系统的定量设计?1. 哈夫曼压缩原理2. Amdahl定律3. cpu性能公式4. 程序访问局部性定理 这样的题已经不多了,主要是要了解下概念。打下一个好的基础。 2023年4月份成绩已经…...
Android中AIDL的简单使用(Hello world)
AIDL:Android Interface Definition Language(Android接口定义语言) 作用:跨进程通讯。如A应用调用B应用提供的接口 代码实现过程简述: A应用创建aidl接口,并且创建一个Service来实现这个接口(…...
ZED使用指南(五)Camera Controls
七、其他 1、相机控制 (1)选择视频模式 左右视频帧同步,以并排格式作为单个未压缩视频帧流式传输。 在ZED Explorer或者使用API可以改变视频的分辨率和帧率。 (2)选择输出视图 ZED能以不同的格式输出图像…...
wrk泛洪攻击监控脚本
wrk泛洪攻击介绍 WRK泛洪攻击(WRK Flood Attack)是一种基于WRK工具进行的DDoS攻击(分布式拒绝服务攻击)。WRK是一个高度并行的HTTP负载生成器,可以模拟大量用户访问一个网站,从而导致该网站服务器瘫痪或失效…...
软件I2C读写MPU6050代码
1、硬件电路 SCL引到了STM32的PB10号引脚,SDA引到了PB11号引脚软件I2C协议: 用普通GPIO口,手动反转电平实现协议,不需要STM32内部的外设资源支持,故端口是可以任意指定MPU605在SCL和SDA自带了两个上拉电阻,…...
销售/回收DSOS254A是德keysight MSOS254A混合信号示波器
Agilent DSOS254A、Keysight MSOS254A、 混合信号示波器,2.5 GHz,20 GSa/s,4 通道,16 数字通道。 Infiniium S 系列示波器 信号保真度方面树立新标杆 500 MHz 至 8 GHz 出色的信号完整性使您可以看到真实显示的信号࿱…...
RIDGID里奇金属管线检测仪故障定位仪维修SR-20KIT
里奇RIDGID管线定位仪/检测仪/探测仪维修SR-20 SR-24 SR-60 美国里奇SeekTech SR-20管线定位仪对于初次使用定位仪的用户或经验丰富的用户,都同样可以轻易上手使用SR-20。SR-20提供许多设置和参数,使得大多数复杂的定位工作变得很容易。此外,…...
NodeJs之调试
关于调试 当我们只专注于前端的时候,我们习惯性F12,这会给我们带来安全与舒心的感觉。 但是当我们使用NodeJs来开发后台的时候,我想噩梦来了。 但是也别泰国担心,NodeJs的调试是很不方便!这是肯定的。 但是还好&…...
Java面试知识点(全)- Java并发-多线程JUC二-原子类/锁
Java面试知识点(全) 导航: https://nanxiang.blog.csdn.net/article/details/130640392 注:随时更新 JUC原子类 什么是CAS CAS的全称为Compare-And-Swap,直译就是对比交换。是一条CPU的原子指令,其作用是让CPU先进行比较两个值…...
CSS--移动web基础
01-移动 Web 基础 谷歌模拟器 模拟移动设备,方便查看页面效果 屏幕分辨率 分类: 物理分辨率:硬件分辨率(出厂设置)逻辑分辨率:软件 / 驱动设置 结论:制作网页参考 逻辑分辨率 视口 作用&a…...
Appuploader 常见错误及解决方法
转载:Appuploader 常见错误及解决方法 问题解决秘籍 遇到问题,第一个请登录苹果开发者官网 检查一遍账号是否有权限,是否被停用,是否过期,是否有协议需要同意,并且在右上角切换账号后检查所有关联的账号是否…...
消息通知之系统层事件发布相关流程
前言 Openharmony 3.1Release中存在消息通知的处理,消息通知包括系统层事件发布、消息订阅、消息投递与处理,为了开发者能够熟悉消息的处理流程,本篇文章主要介绍系统层事件发布的相关流程。 整体流程 代码流程 发布消息 { eventAction)w…...
Elsevier Ocean Engineering Guide for Authors 解读
文章目录 ★Types of contributions★Submission checklistEthics in publishing★Declaration of competing interestDeclaration of generative AI in scientific writingSubmission declaration and verificationPreprint posting on SSRNUse of inclusive languageReportin…...
基于Fragstats的土地利用景观格局分析
土地利用以及景观格局是当前全球环境变化研究的重要组成部分及核心内容,其对区域的可持续发展以及区域土地管理有非常重要的意义。通过对土地利用时空变化规律进行分析可以更好的了解土地利用变化的过程和机制,并且通过调整人类社会经济活动,…...
ffmpeg-转码脚本02
ffmpeg-转码脚本详解 高级脚本 以下为主要部分 更高级优化要见git上 mkv转码电影脚本 ECHO OFF REM 以下参数不可乱填 SET FFMPEG%~DP0\ffmpeg.exe ::------------------------------------------------------------------------------ CALL:PRO_LOOPDIR ::CALL:PRO_LOOPDIR_SU…...
FastAPI子应用挂载:别再让root_path坑你一夜闭
Julia(julialang.org)由Stefan Karpinski、Jeff Bezanson等在2009年创建,目标是融合Python的易用性、C的高性能、R的统计能力、Matlab的科学计算生态。 其核心设计哲学是: 高性能:编译型语言(JIT࿰…...
基于yolo26算法的大坝缺陷识别 智慧水利工程监测 防寒抗洪监测 水坝安全防护监测 水利工程安全监测 坝体结构状态分析第10428期
数据集说明一、核心信息概览项目详情类别数量及中文名称2 类,分别为: 裂缝、剥落数据总量1400 条(图像数据)数据集格式种类YOLO 格式最重要应用价值支持大坝坝段实例分割模型训练,为水利工程安全监测、坝体结构状态分析…...
.NET 诊断技巧 | 日志框架原理、手写日志框架学习汕
一、 什么是 AI Skills:从工具级到框架级的演化 AI Skills(AI 技能) 的概念最早在 Claude Code 等前沿 Agent 实践中被强化。最初,Skills 被视为“工具级”的增强,如简单的文件读写或终端操作,方便用户快速…...
Vivado FFT IP核避坑指南:从Matlab数据生成到FPGA验证的完整流程
Vivado FFT IP核实战避坑指南:从Matlab数据生成到FPGA验证的全链路解析 在FPGA信号处理领域,FFT(快速傅里叶变换)是实现频域分析的核心运算单元。Xilinx Vivado提供的FFT IP核虽然功能强大,但在实际工程落地过程中&…...
车辆三自由度运动学模型; Carsim_Simulink联合仿真; 无人驾驶车辆模型预测控制(2.1);
车辆三自由度运动学模型; Carsim/Simulink联合仿真; 无人驾驶车辆模型预测控制(2.1); 包括Carsim的设置、控制信号数据、PPT文件、cpar件、车辆运动分析图(适用于word两栏布局);Simu…...
LumiPixel Canvas Quest多模态初探:结合文本描述生成角色设定图
LumiPixel Canvas Quest多模态初探:结合文本描述生成角色设定图 1. 多模态创作的新可能 最近试用LumiPixel Canvas Quest时,最让我惊喜的是它处理复杂文本描述的能力。不同于简单的文生图工具,这款模型真正展现了多模态理解的潜力——它能将…...
MATLAB+CPLEX仿真平台下的微网虚拟电厂日前优化调度模型:融合电动汽车出行及充放电规律...
MATLAB代码:含多种需求响应及电动汽车的微网/虚拟电厂日前优化调度 关键词:需求响应 空调负荷 电动汽车 微网优化调度 虚拟电厂调度 仿真平台:MATLABCPLEX 主要内容:代码主要做的是一个微网/虚拟电厂的日前优化调度模型&#…...
深度拆解 Redis ZSet 底层实现:从“紧凑排队”到“多级瞬移”
在 Redis 的世界里,为了把性能和内存利用率压榨到极致,底层实现往往是“看人下菜碟”。今天咱们就揭开 ZSet 的底裤,看看它到底是怎么从“紧凑排队”进化到“多级瞬移”的。 一、 是什么:ZSet 的“两副面孔” 首先纠正一个小插曲…...
TinyTemplateEngine:嵌入式行级模板引擎深度解析
1. TinyTemplateEngine:面向资源受限嵌入式平台的行级模板引擎深度解析在嵌入式Web服务、动态HTML生成、设备状态报告等场景中,开发者常需将运行时变量注入静态文本模板。传统方案(如String拼接、sprintf全量缓存)在Arduino Uno&a…...
CSS如何利用Flex实现两层结构的嵌套布局_掌握父子容器的Flex属性继承
Flex布局作用域仅限直接子元素,嵌套层需显式设置display: flex;align-items不影响子项内部对齐;inline元素需转为block或inline-flex才生效;flex: 1依赖父容器高度约束;IE11嵌套flex支持差,建议用-ms-flex或…...
