【LeetCode链表#10】删除链表中倒数第n个节点(双指针)
删除链表倒数第N个节点
给你一个链表,删除链表的倒数第 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]
思路
最开始我是想先把链表翻转,然后遍历到第n个节点,将其删除,然后再把链表翻转并返回
这么做显然提升了代码复杂度,以至于我并没有写出逻辑正常的代码,并且我估计写出来也超时了
参考删除第n个链表节点的操作
我们可以发现:要删除某个节点,当前指针cur必须指向待删除节点的前一个节点

这样,通过将cur指向下一个节点的下一个节点就可以把待删除节点移除
明确了删除方式之后,那么如何找到倒数第n个节点?
这里需要引入双指针思想,分别定义快慢指针指向dummy

快指针fast先移动n步

然后快慢指针一起向后移动,直到快指针指向null

此时,slow指向的就是倒数第n个节点
但是根据删除节点的操作,现在的情况我们是删不了slow指向的节点的,只能删除下一个
即慢指针slow要指向待删除节点的前一个
所以快指针fast应该先走n+1步

代码
class Solution {
public ListNode removeNthFromEnd(ListNode head, int n) {
//双指针法
//创建dummy
ListNode dummy = new ListNode(0);
dummy.next = head;
//快慢指针指向dummy
ListNode fast = dummy;
ListNode slow = dummy;
n++;//让fast走n+1步
for(int i = n; i > 0; i--){
if(fast == null){//避免走着走着到链表尾部的情况
break;
}
fast = fast.next;
}
//快慢指针一起移动
while(fast != null){
fast = fast.next;
slow = slow.next;
}
//注意删除操作
slow.next = slow.next.next;
return dummy.next;
}
}
c++版
步骤:
1、创建dummy并指向head
2、创建快慢指针并指向dummy
3、快指针先走n+1步(记得处理非法情况,如果fast为NULL就停止遍历)
4、快慢指针一块移动,当fast为空时停止
5、将当前的slow->next指向slow->next->next,返回dummy->next
class Solution {
public:
ListNode* removeNthFromEnd(ListNode* head, int n) {
//创建dummy
ListNode* dummy = new ListNode(0, head);
////创建快慢指针
ListNode* fast = dummy;
ListNode* slow = dummy;
//快指针先走n+1步
n++;
while(n--){
//避免走着走着到链表尾部的情况
if(fast == NULL){
break;
}
fast = fast->next;
}
//快慢指针一起移动
while(fast != nullptr){
fast = fast->next;
slow = slow->next;
}
//删除待删除节点
slow->next = slow->next->next;
return dummy->next;
}
};
易错点
1、为了让慢指针落在待删除节点前,快指针需要先走n+1步
并且不能写成:
for(int i = n; i > 0; i--){
if(fast == null){//避免走着走着到链表尾部的情况
break;
}
fast = fast.next;
}
fast = fast.next;
因为如果n大于链表长度,那之后就相当于对空指针进行操作了
2、删除操作
删除操作是
slow.next = slow.next.next;//让待删除节点直接等于它之后的一个节点,即代替掉要删除的节点
而不是
slow = slow.next.next;//移动slow到它的下下一个位置
3、注意要判断fast是否为空,而不是fast->next
【LeetCode链表#10】删除链表中倒数第n个节点(双指针)的更多相关文章
- 剑指offer-面试题22-链表中倒数第k个节点-双指针
/* 题目: 链表中倒数第k个节点 */ /* 思路: 考虑边界条件:链表为空,k值超过链表长度. 双指针: q指针指向第k个节点,p指针指向第1个节点. q指针指向最后一个节点,p指针指向倒数第k个 ...
- 链表中倒数第k个节点 双指针
- LeetCode 19. Remove Nth Node From End of List(删除链表中倒数第N个节点)
题意:删除链表中倒数第N个节点. 法一:递归.每次统计当前链表长度,如果等于N,则return head -> next,即删除倒数第N个节点:否则的话,问题转化为子问题“对head->n ...
- lintcode:Remove Nth Node From End of Lis 删除链表中倒数第n个节点
题目: 删除链表中倒数第n个节点 给定一个链表,删除链表中倒数第n个节点,返回链表的头节点. 样例 给出链表1->2->3->4->5->null和 n = 2. 删除 ...
- 删除链表中倒数第n个节点
给定一个链表,删除链表中倒数第n个节点,返回链表的头节点. 样例 给出链表1->2->3->4->5->null和 n = 2. 删除倒数第二个节点之后,这个链表将变成1 ...
- lintcode174 删除链表中倒数第n个节点
删除链表中倒数第n个节点 给定一个链表,删除链表中倒数第n个节点,返回链表的头节点. 注意事项 链表中的节点个数大于等于n 您在真实的面试中是否遇到过这个题? Yes 样例 给出链表1->2 ...
- LintCode-174.删除链表中倒数第n个节点
删除链表中倒数第n个节点 给定一个链表,删除链表中倒数第n个节点,返回链表的头节点. 注意事项 链表中的节点个数大于等于n 样例 给出链表 1->2->3->4->5-> ...
- 174. 删除链表中倒数第n个节点
描述 笔记 数据 评测 给定一个链表,删除链表中倒数第n个节点,返回链表的头节点. 注意事项 链表中的节点个数大于等于n 您在真实的面试中是否遇到过这个题? Yes 样例 给出链表1->2-&g ...
- 【leetcode】19. 删除链表的倒数第N个节点
描述 给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点. 示例 给定一个链表: 1->2->3->4->5, 和 n = 2. 当删除了倒数第二个节点后,链表变 ...
- LeetCode 19:删除链表的倒数第N个节点 Remove Nth Node From End of List
给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点. Given a linked list, remove the n-th node from the end of list and ...
随机推荐
- [转帖]Elasticsearch-索引性能调优
1:设置合理的索引分片数和副本数 索引分片数建议设置为集群节点的整数倍,初始数据导入时副本数设置为 0,生产环境副本数建议设置为 1(设置 1 个副本,集群任意 1 个节点宕机数据不会丢失:设置更多副 ...
- [转帖]将nginx.conf文件的内容拆分成多个
nginx的如果有多个server模块都配置在同一个nginx.conf文件会显得比较臃肿,后续维护起来也会比较困难,所以可以将内容写入到多个配置文件中然后在nginx.conf文件中通过includ ...
- JRC Flink流作业调优指南
# 作者:京东物流 康琪 本文综合Apache Flink原理与京东实时计算平台(JRC)的背景,详细讲述了大规模Flink流作业的调优方法.通过阅读本文,读者可了解Flink流作业的通用调优措施,并 ...
- 自动化部署实例(donetcore GitLab CICD )
主要简单的介绍了一下 GitLab CI 的持续集成以及持续部署,这篇将通过 GitLab CI 发布一个 .net core 项目,来带小伙伴们感受一下自动化的魅力,从此告别手动发布. 准备工作 创 ...
- 如何通过gRPC传输文件
在gRPC中,可以通过将文件分割成多个小块,然后使用流式RPC将这些小块发送到服务器来传输文件.以下是一个简单的示例,展示了如何在gRPC中实现文件传输. 首先,我们需要定义一个服务来处理文件传输.在 ...
- Windows 堆管理机制 [3] Windows XP SP2 – Windows 2003 版本
3. Windows XP SP2 – Windows 2003 3.1 环境准备 环境 环境准备 虚拟机 32位Windows XP SP2 \32位Windows XP SP3 调试器 OllyD ...
- 5.10 Windows驱动开发:摘除InlineHook内核钩子
在笔者上一篇文章<内核层InlineHook挂钩函数>中介绍了通过替换函数头部代码的方式实现Hook挂钩,对于ARK工具来说实现扫描与摘除InlineHook钩子也是最基本的功能,此类功能 ...
- MySQL 数据库读写分离
MySQL 是最流行的关系型数据库管理系统,MySQL 配置主备模式,基于一台服务器的数据复制,故得名单机热备,主-备 Active-Standby主-备方式,即指的是一台服务器处于某种业务的激活状态 ...
- WebAssembly入门笔记[4]:利用Global传递全局变量
利用WebAssembly的导入导出功能可以灵活地实现宿主JavaScript程序与加载的单个wasm模块之间的交互,那么如何在宿主程序与多个wasm之间传递和共享数据呢?这就需要使用到Global这 ...
- spring框架中RESTFUL接口相关注解
1.说明 springboot 是国内最常用的web框架,因为它的http server功能是最重要的.本文列举了一些现在通用的restful形式的接口所需要的注解 2.@RequestMapping ...