[每日算法 - 阿里机试] leetcode19. 删除链表的倒数第 N 个结点

本文主要是介绍[每日算法 - 阿里机试] leetcode19. 删除链表的倒数第 N 个结点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

入口

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/remove-nth-node-from-end-of-list/description/

题目描述

给你一个链表,删除链表的倒数第 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]

提示:

  • 链表中结点的数目为 sz
  • 1 <= sz <= 30
  • 0 <= Node.val <= 100
  • 1 <= n <= sz

方法一:栈

Java实例

class Solution {public ListNode removeNthFromEnd(ListNode head, int n) {// 创建一个虚拟节点作为头节点,以便在删除第一个节点时能够方便地处理ListNode dummy = new ListNode(0, head);// 创建一个栈来保存节点,用于倒数第n个节点的查找Deque<ListNode> stack = new LinkedList<ListNode>();// 创建一个当前节点指针,初始化为虚拟节点ListNode cur = dummy;// 将链表中的每个节点推入栈中while (cur != null) {stack.push(cur);cur = cur.next;}// 弹出栈中的前n个节点,使栈顶元素为倒数第n个节点的前一个节点for (int i = 0; i < n; ++i) {stack.pop();}// 获取倒数第n个节点的前一个节点ListNode prev = stack.peek();// 将前一个节点的next指针跳过倒数第n个节点,直接指向倒数第n个节点的下一个节点prev.next = prev.next.next;// 获取新链表的头节点(去除了虚拟节点)ListNode ans = dummy.next;// 返回新链表的头节点return ans;}
}

复杂度分析

  • 时间复杂度:O(L), L 是链表的长度。

  • 空间复杂度:O(L), L 是链表的长度,主要为栈的开销。

方法二:双指针

        使用快慢指针的方式,快指针与慢指针相差n-1,即快指针比慢指针超前了 n 个节点。 两个指针同时遍历链表,当快指针指向null时,此时慢指针正好指向倒数第n个元素。

Java示例

class Solution {public ListNode removeNthFromEnd(ListNode head, int n) {// 创建一个虚拟节点,用于处理删除第一个节点的情况ListNode dummy = new ListNode(0, head);// 创建两个指针,一个指向链表的头节点,另一个指向虚拟节点ListNode first = head;ListNode second = dummy;// 将第一个指针向前移动n个节点for (int i = 0; i < n; ++i) {first = first.next;}// 同时移动第一个和第二个指针,直到第一个指针到达链表末尾while (first != null) {first = first.next;second = second.next;}// 此时第二个指针指向倒数第n个节点的前一个节点// 将前一个节点的next指针跳过倒数第n个节点,直接指向倒数第n个节点的下一个节点second.next = second.next.next;// 获取新链表的头节点(去除了虚拟节点)ListNode ans = dummy.next;// 返回新链表的头节点return ans;}
}

复杂度分析

  • 时间复杂度:O(L),L 是链表的长度。

  • 空间复杂度:O(1)。

这篇关于[每日算法 - 阿里机试] leetcode19. 删除链表的倒数第 N 个结点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/154891

相关文章

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

docker如何删除悬空镜像

《docker如何删除悬空镜像》文章介绍了如何使用Docker命令删除悬空镜像,以提高服务器空间利用率,通过使用dockerimage命令结合filter和awk工具,可以过滤出没有Tag的镜像,并将... 目录docChina编程ker删除悬空镜像前言悬空镜像docker官方提供的方式自定义方式总结docker

使用Python在Excel中插入、修改、提取和删除超链接

《使用Python在Excel中插入、修改、提取和删除超链接》超链接是Excel中的常用功能,通过点击超链接可以快速跳转到外部网站、本地文件或工作表中的特定单元格,有效提升数据访问的效率和用户体验,这... 目录引言使用工具python在Excel中插入超链接Python修改Excel中的超链接Python

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C#实现添加/替换/提取或删除Excel中的图片

《C#实现添加/替换/提取或删除Excel中的图片》在Excel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更加美观,下面我们来看看如何在C#中实现添加/替换/提取或删除E... 在Excandroidel中插入与数据相关的图片,能将关键数据或信息以更直观的方式呈现出来,使文档更

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Git中恢复已删除分支的几种方法

《Git中恢复已删除分支的几种方法》:本文主要介绍在Git中恢复已删除分支的几种方法,包括查找提交记录、恢复分支、推送恢复的分支等步骤,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录1. 恢复本地删除的分支场景方法2. 恢复远程删除的分支场景方法3. 恢复未推送的本地删除分支场景方法4. 恢复

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

Oracle数据库使用 listagg去重删除重复数据的方法汇总

《Oracle数据库使用listagg去重删除重复数据的方法汇总》文章介绍了在Oracle数据库中使用LISTAGG和XMLAGG函数进行字符串聚合并去重的方法,包括去重聚合、使用XML解析和CLO... 目录案例表第一种:使用wm_concat() + distinct去重聚合第二种:使用listagg,

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1