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

【LeetCode 刷题日】19.删除链表的倒数第n个节点

个人主页北极的代码欢迎来访作者简介java后端学习者评论和❄️个人专栏苍穹外卖日记SSM框架深入JavaWeb✨命运的结局尽可永在不屈的挑战却不可须臾或缺前言继续对链表的学习暴打LeetCode接下来就快到了哈希表其实我在写这些算法之前看过一些关于数据结构的书有的书上来就是摆一堆源码看的迷迷糊糊的有的又太过于简单了目前还没找到很合适的书有没有大佬有推荐的以及一些计算机基础四大件的数据。题目背景LeetCode19给你一个链表删除链表的倒数第 n 个结点并且返回链表的头结点。进阶你能尝试使用一趟扫描实现吗示例 1输入head [1,2,3,4,5], n 2 输出[1,2,3,5]示例 2输入head [1], n 1 输出[]示例 3输入head [1,2], n 1 输出[1]题目答案class Solution { public ListNode removeNthFromEnd(ListNode head, int n) { //新建一个虚拟头节点指向head ListNode dummyNode new ListNode(0); dummyNode.next head; //快慢指针指向虚拟头节点 ListNode fastIndex dummyNode; ListNode slowIndex dummyNode; // 只要快慢指针相差 n 个结点即可 for (int i 0; i n; i) { fastIndex fastIndex.next; } while (fastIndex ! null) { fastIndex fastIndex.next; slowIndex slowIndex.next; } // 此时 slowIndex 的位置就是待删除元素的前一个位置。 // 具体情况可自己画一个链表长度为 3 的图来模拟代码来理解 // 检查 slowIndex.next 是否为 null以避免空指针异常 if (slowIndex.next ! null) { slowIndex.next slowIndex.next.next; } return dummyNode.next; } }题目解析双指针的经典应用如果要删除倒数第n个节点让fast移动n步然后让fast和slow同时移动直到fast指向链表末尾。删掉slow所指向的节点就可以了。思路是这样的但要注意一些细节。这时就有同学不理解为什么快指针要先走n步当然快指针肯定是比慢指针快的从名字就看出来了但具体原理是什么呢简单的来说先走n步就是为了制造快慢指针之间的间距那为什么要制造间距呢首先要明确题目要干嘛要删除倒数第n个节点根据链表的特性我们删除一个节点必须要知道这个节点的前驱节点所以我们做的一切都是为了让慢指针最后停在要删除节点的前置节点那个位置。这样才能slow.next slow.next.next删掉目标节点。因此我们看流程图解为什么快指针要先走 n 步举个最清晰的例子链表1 → 2 → 3 → 4 → 5n 2要删除倒数第 2 个节点 4初始状态plaintextfast slow ↓ 1 → 2 → 3 → 4 → 5 → null① 快指针先走 n 步n2走 2 步plaintextfast slow ↓ ↓ 1 → 2 → 3 → 4 → 5 → null此时快慢相差 n 个节点② 快慢一起走直到 fast 到末尾plaintextfast slow ↓ ↓ 1 → 2 → 3 → 4 → 5 → nullslow 正好停在 3是 4 的前一个③ 删除plaintextslow.next slow.next.next结果1 → 2 → 3 → 5 → null先走 n 步 也就是为了拉开 n 步距离一起走到头 代表着慢指针刚好落在倒数第 n 个的前一个没有这 n 步我们根本定位不到要删的节点因此我们在代码里的for循环就是为了提前让快节点先走n次领先条件理解fast.next ! null的意思是快节点还没走到最后一个节点因为最后一个节点的下一个就是null链表默认的if (slowIndex.next ! null)这里if里面的条件判断是为了防止空指针异常也就是为了防止slow.next.next;空指针关于这里的虚拟头节点我们已经很清楚了它仅仅是为了让头节点与其他的节点平级。结语如果对你有帮助请点赞关注收藏你的支持就是我最大的鼓励

相关文章:

【LeetCode 刷题日】19.删除链表的倒数第n个节点

🔥个人主页:北极的代码(欢迎来访) 🎬作者简介:java后端学习者评论和 ❄️个人专栏:苍穹外卖日记,SSM框架深入,JavaWeb ✨命运的结局尽可永在,不屈的挑战却不可…...

【AI实战项目】项目六:知识图谱构建与应用实战

分享一个大牛的人工智能教程。零基础!通俗易懂!风趣幽默!希望你也加入到人工智能的队伍中来!请轻击人工智能教程https://www.captainai.net/troubleshooter 项目背景: 在当今信息爆炸的时代,精准理解和应…...

人流后多久干净才算正常?行业洞察与科学修护指南

人工流产后,出血排净时间是判断身体恢复状态的核心指标,也是女性关注的首要问题。结合行业研究与临床实践,本文将深入解析人流后出血的正常范围、异常信号,同时结合行业修护标准,为女性提供科学、实用的恢复指引&#…...

宫外孕打掉需要住院吗?术后修护核心指南

宫外孕作为妇科高发急腹症,不少女性存在认知误区,疑惑“宫外孕打掉是否需要住院”。事实上,宫外孕绝非普通流产,其处理必须住院,且术后修护直接影响女性后续生殖健康。本文结合行业洞察,围绕宫外孕住院必要…...

告别繁琐手工操作:工资条生成器使用指南

对于许多财务人员来说,每月制作工资条都是一项让人头疼的工作。 手工制作不仅要花费大量时间,还容易出现各种错误,影响工作效率和准确性。 今天,我们就来详细介绍一款能够彻底改变这种状况的工具——工资条生成器。 工资条生成…...

工资条生成器:财务人员的高效办公利器

在企业财务管理工作中,工资条的制作与发放是一项既繁琐又重要的任务。 传统的手工制作方式不仅耗时耗力,还容易出现数据错误和格式不统一的问题。 工资条生成器的出现,为财务人员带来了全新的解决方案。 这款软件专门针对财务工作场景设计…...

龙迅LT9211D芯片解析:如何实现MIPI与双端口LVDS的高效转换

1. 龙迅LT9211D芯片的核心价值 第一次接触龙迅LT9211D芯片是在一个车载显示项目上,当时客户要求实现4K视频从主控芯片到双屏显示的无损传输。这个看似简单的需求背后,其实隐藏着MIPI和LVDS两种信号标准的转换难题。LT9211D的出现完美解决了这个问题&…...

Ubuntu 22.04下Milvus集群部署实战:从Docker提取二进制文件的完整指南

Ubuntu 22.04下Milvus集群部署实战:从Docker提取二进制文件的完整指南 在向量数据库领域,Milvus凭借其出色的性能和可扩展性已成为众多AI应用的首选存储引擎。虽然官方推荐使用Docker或Kubernetes进行部署,但在某些生产环境中,直接…...

W5500 TCP客户端实战 | 02 - 从寄存器配置到数据收发的完整流程解析

1. W5500网络寄存器配置详解 第一次接触W5500芯片时,我被它密密麻麻的寄存器地址搞得头晕眼花。后来发现只要抓住几个核心寄存器,配置起来就像填快递单一样简单。先说说最关键的四个本地网络寄存器,它们相当于设备的"身份证"&#…...

小米笔记本Pro双固态硬盘实战:Win11与Ubuntu22.04双系统完美共存指南

1. 为什么选择双固态硬盘装双系统? 最近给小米笔记本Pro加装第二块NVMe固态硬盘的朋友越来越多,我自己也刚在2023款小米Pro上实现了Win11和Ubuntu22.04的双系统共存。相比传统单硬盘分区方案,双物理硬盘隔离安装有几个明显优势: 首…...

从实战到复盘:K8s服务器电子数据取证竞赛全解析与核心技巧

1. K8s服务器电子数据取证竞赛全景解析 第一次参加K8s服务器电子数据取证竞赛时,我完全被复杂的集群环境搞懵了。三个节点、七个命名空间、近20个Pod,还有各种加密算法和数据库连接,简直像走进了一个技术迷宫。但经过几轮实战后,我…...

别再死记硬背了!用这3个真实场景,彻底搞懂Koa中间件的洋葱模型

用三个实战案例拆解Koa中间件的洋葱模型 当你第一次听说Koa的"洋葱模型"时,是不是也和我一样,脑子里浮现出一个奇怪的画面:一个请求像剥洋葱一样,一层层往里钻,然后又一层层往外冒?但真正开始写代…...

2025届学术党必备的六大降重复率神器横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 当前,人工智能技术快速发展,这为毕业论文写作提供了新的辅助路径&…...

2026届必备的十大降重复率工具实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 当前,人工智能生成内容于各类文本里的广泛运用引发了对于原创性以及真实性的关注…...

保姆级教程:在CentOS 7.9上从源码编译安装nvtop 3.1.0(含CMake 3.29.7依赖安装)

在CentOS 7.9上从源码构建GPU监控神器nvtop 3.1.0的全流程指南 当你面对一台运行CentOS 7.9的老旧服务器,需要实时监控NVIDIA、AMD或Intel GPU的运行状态时,nvtop无疑是最佳选择之一。这款类似htop的工具能直观展示GPU使用率、温度、显存占用等关键指标&…...

“16QAM调制与解调系统的SystemView仿真及分析”

通信原理 systemview 16QAM调制与解调系统的仿真 16QAM调制解调系统与解调系统的仿真 用SystemView建立一个16QAM调制解调器电路,分析理解系统的各个模块功能,观察波形图 判断是不是实现了16QAM调制解调系统功能 基本要求: (1)在SystemView软 件中构建短波16QAM仿真…...

DSI3协议四大模式(CRM/PDCM/BDM/DM)全解析:从汽车胎压监测到电池管理,看它如何工作

DSI3协议四大模式深度解析:从胎压监测到电池管理的实战应用 汽车电子系统正经历着从分布式架构向集中式控制的转型,而DSI3(Distributed System Interface 3)协议凭借其独特的单线通信设计,正在成为连接各类车载传感器的…...

MATLAB六自由度齿轮弯扭耦合动力学代码(含时变啮合刚度、齿侧间隙及集中质量法建模的数值计算分析)

MATLAB六自由度齿轮弯扭耦合动力学代码(考虑时变啮合刚度、齿侧间隙),根据集中质量法建模(含数学方程建立和公式推导)并在MATLAB中采用ODE45进行数值计算。 输出齿轮水平和竖直方向的振动位移、振动速度、振动加速度、…...

OpenClaw 入门:新一代 AI 智能助手平台全景解析

OpenClaw 入门:新一代 AI 智能助手平台全景解析 本文是「OpenClaw 研究」专题的第一篇,带你全面了解这个新兴的 AI 智能助手平台。 一、什么是 OpenClaw? OpenClaw 是一个开源的 AI 智能助手平台,旨在帮助开发者和企业快速构建、…...

剧本杀app2025推荐,多类型剧本体验与社交互动优势

剧本杀app2025推荐,多类型剧本体验与社交互动优势在当今娱乐多元化的时代,剧本杀凭借其独特的角色扮演和推理乐趣,成为了众多年轻人喜爱的社交娱乐方式。据《2025 年中国剧本杀行业发展报告》显示,2025 年剧本杀市场规模持续增长&…...

生成剧本杀软件2025推荐,创新剧情设计工具引领潮流

剧本杀软件2025推荐,创新剧情设计工具引领潮流随着剧本杀市场的蓬勃发展,越来越多的创作者和玩家对剧本杀软件的需求日益增长。为了帮助大家在众多选择中找到最适合自己的工具,本文将推荐一款在2025年备受瞩目的剧本杀软件——量子探险AI漫剧…...

打造行业大模型更好还是做垂直 Agent 更好

打造行业大模型更好还是做垂直 Agent 更好?从小学生的糖果王国管理谈起,拆解AI落地的终极选择题关键词:行业大模型、垂直 Agent、AI落地、通用 vs 垂直、能力边界、ROI模型、端云协同、大模型Agent架构摘要:这篇文章从「小学生管理…...

文章标题:专业ASIC FPGA IP加密代码解密工具

专业 ASIC FPGA IP 加密代码解密工具 支持 Xilinx Vivado IP 解密,包括 ip、vp、iip、vip、dw、rtl、run 包等;还支持解密 Verilog、VHDL、SystemVerilog(sv、svp、svh、svi)等多种语言,能够解密所有加密文件 解密工具…...

信通院:AI4SE行业现状调查报告 2026

这份信通院 2026 年 AI4SE 行业现状调查报告,核心是 AI 与软件工程深度融合进入规模化落地关键期,全流程提效显著,企业高度重视,但仍面临人才、成本等挑战,未来将走向自主编程、多智能体协同的新范式。一、调研概况有效…...

甲子光年:AI原生组织——OpenClaw推动组织形态重塑 2026

这份《AI 原生组织:OpenClaw 推动组织形态重塑》报告核心内容可概括为:一、OpenClaw:引爆 AI Agent 的现象级开源框架定位:开源 AI Agent 框架,从个人 AI 助手快速向 B 端延展,4 个月实现行业十年发展&…...

智能电池充电:使用PID控制器优化SOC附Matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室🍊个人信条:格物致知,完整Matlab代码及仿真咨询…...

2025届学术党必备的六大AI论文助手解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek DeepSeek身为人工智能写作工具,于学术论文撰写里能够起到辅助方面的作用&#xf…...

告别数据孤岛:手把手教你用ArcMap的Join功能,把Excel数据精准‘贴’到地图上

数据可视化实战:用ArcMap的Join功能将Excel业务数据转化为空间洞察 在商业分析和区域规划中,最令人头疼的莫过于面对一堆冰冷的Excel数字却无法直观看到它们在地理空间上的分布规律。想象一下,当销售总监拿到全国各城市的业绩报表时&#xff…...

Avalonia实战:5分钟搞定无边框窗口自定义(附拖拽功能完整代码)

Avalonia实战:5分钟实现无边框窗口与拖拽功能全解析 第一次接触Avalonia的无边框窗口时,我花了整整一天时间才搞明白各种属性的作用。现在回想起来,如果能有一篇直击要点的指南,至少能节省80%的调试时间。本文将带你快速掌握两种取…...

5个技巧让你高效畅玩Switch游戏:开源Ryujinx模拟器全攻略

5个技巧让你高效畅玩Switch游戏:开源Ryujinx模拟器全攻略 【免费下载链接】Ryujinx 用 C# 编写的实验性 Nintendo Switch 模拟器 项目地址: https://gitcode.com/GitHub_Trending/ry/Ryujinx Ryujinx是一款采用C#语言开发的开源Nintendo Switch模拟器&#x…...