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

19.删除链表的倒数第 N 个节点

题目来源:

        leetcode题目,网址:19. 删除链表的倒数第 N 个结点 - 力扣(LeetCode)

解题思路:

       使用双指针找到倒数第 N+1 个节点后删除链表的第 N 个节点即可。注意当 N 为链表长度时,倒数第 N+1 个节点不存在,head->next 即为所求。

解题代码:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* removeNthFromEnd(ListNode* head, int n) {ListNode* lastNPlusOne=head;ListNode* lastOne=head;for(int i=0;i<n;i++){lastOne=lastOne->next;}if(lastOne==nullptr){return head->next;}while(lastOne->next!=nullptr){lastNPlusOne=lastNPlusOne->next;lastOne=lastOne->next;}lastNPlusOne->next=lastNPlusOne->next->next;return head;        }
};

总结:

        官方题解新增了哑节点作为头节点以避免删除首个元素时的特殊判断。官方题解给出了三种解法。第一种是计算链表长度。两次遍历,第一次获得链表长度,第二次删除指定节点。第二种是栈,将所有元素入栈后,删去出栈时位于倒数第 N 个的节点。第三种是双指针。


http://www.lryc.cn/news/238620.html

相关文章:

  • 机器人制作开源方案 | 莲花灯
  • 华为无线ac+fit三层组网,每个ap发射不同的业务vlan
  • 人工智能:科技之光,生活之美
  • mysql8.0英文OCP考试第61-70题
  • WaveletPool:抗混叠在微小目标检测中的重要性
  • 文章系列2:Unraveling the functional dark matter through global metagenomics
  • ubuntu 20.04 搭建crash dump问题分析环境
  • 算法训练营一刷 总结篇
  • Linux中的MFS分布式文件系统
  • 气相色谱质谱仪样品传输装置中电动针阀和微泄漏阀的解决方案
  • ArkTS基础知识
  • Kotlin学习(二)
  • LangChain 6根据图片生成推广文案HuggingFace中的image-caption模型
  • QFontDialog开发详解
  • 【C++进阶之路】第七篇:异常
  • shell 判断文件是否存在(csh bash)
  • 第六年到第十年是分水岭
  • 关于标准库中的string类 - c++
  • Chrome添加扩展程序
  • C++单调向量算法:132模式枚举1简洁版
  • 【ARFoundation学习笔记】2D图像检测跟踪
  • 计算机算法分析与设计(24)---分支限界章节复习
  • 二十三种设计模式-解密状态模式:优雅地管理对象状态
  • git常常用命令
  • C语言中的大端字节序和小端字节序是什么?如何进行字节序的转换?
  • Flutter dio Http请求之Cookie管理
  • 计算机网络的标准化工作及相关组织
  • 智能座舱架构与芯片- (11) 软件篇 上
  • 2021秋招-算法-递归
  • 【Django-02】 Model模型和模型描述对象Meta