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

【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 → 5,n = 2要删除:倒数第 2 个节点 4

初始状态

plaintext

fast slow ↓ 1 → 2 → 3 → 4 → 5 → null

① 快指针先走 n 步(n=2,走 2 步)

plaintext

fast slow ↓ ↓ 1 → 2 → 3 → 4 → 5 → null

👉此时快慢相差 n 个节点

② 快慢一起走,直到 fast 到末尾

plaintext

fast slow ↓ ↓ 1 → 2 → 3 → 4 → 5 → null

👉slow 正好停在 3,是 4 的前一个!

③ 删除

plaintext

slow.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;空指针

关于这里的虚拟头节点,我们已经很清楚了,它仅仅是为了让头节点与其他的节点平级。

结语:如果对你有帮助,请点赞,关注,收藏,你的支持就是我最大的鼓励!

http://www.jsqmd.com/news/594048/

相关文章:

  • Java中什么是嵌套对象?
  • 高功率高密度驱动技术:未来电力电子核心
  • 从实战到复盘:K8s服务器电子数据取证竞赛全解析与核心技巧
  • Vercel agent-browser:为 AI 而生的浏览器自动化工具
  • 小米笔记本Pro双固态硬盘实战:Win11与Ubuntu22.04双系统完美共存指南
  • 【业财一体化财务合集】300份业财一体化、财业一体化、数字财务、智慧财务、财务共享服务、财务管控方案资料合集(PPT+WORD+PDF)
  • 谷歌商店play下载
  • 针对波动计算复杂性的吸收边界条件(PML 用于一般波动方程)附Matlab代码
  • MATLAB六自由度齿轮弯扭耦合动力学代码(含时变啮合刚度、齿侧间隙及集中质量法建模的数值计算分析)
  • 自适应多机器人编队规划,以包围和跟踪具有运动和可见性约束的目标附Matlab代码
  • 用AI提升答辩质量:10款必备工具(含爱毕业)与专业模板测评
  • CEEMDAN-VMD-Transformer-GRU二次分解+编码器+门控循环单元多元时间序列预测
  • 2026届必备的十大降重复率工具实际效果
  • LeetCode 双杀!二叉树最大路径和 + 岛屿数量|DFS 两大经典模板题
  • W5500 TCP客户端实战 | 02 - 从寄存器配置到数据收发的完整流程解析
  • 基于FPGA的LMS自适应滤波器设计与实现(Verilog代码及仿真)
  • 2025届学术党必备的六大降重复率神器横评
  • TCP 和 UDP 有什么区别:从可靠性到速度,从头部到场景
  • BFS 经典双题:腐烂的橘子 + 课程表 | 拓扑排序入门必刷
  • 别再只调参了!深入torchvision.datasets.CIFAR10源码,理解PyTorch数据加载的设计哲学
  • 2025届学术党必备的六大AI论文助手解析与推荐
  • Ubuntu 22.04下Milvus集群部署实战:从Docker提取二进制文件的完整指南
  • 基于Simulink的四自由度磁悬浮轴承控制仿真:电流环、位置环、位移解析及磁轴承模型PID控...
  • DSI3协议四大模式(CRM/PDCM/BDM/DM)全解析:从汽车胎压监测到电池管理,看它如何工作
  • 1Panel面板深度体验:比宝塔更轻量的Docker管理方案?CasaOS环境实测对比
  • 为什么要 TCP,IP 层实现控制不行么:从分层哲学到不可逾越的物理限制
  • 2026-4-5
  • Python办公自动化:3种Word转PDF方法实测(附代码对比)
  • 前端必懂:开发环境、构建打包的核心差异,新手再也不踩坑
  • 深度学习检测不准确智能电表案例研究代码功能说明