力扣热搜一百题之19.删除链表的倒数第n个节点

2024-04-21 22:18

本文主要是介绍力扣热搜一百题之19.删除链表的倒数第n个节点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述:

给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。

示例:

给定一个链表: 1->2->3->4->5, 和 n = 2.

当删除了倒数第二个节点后,链表变为 1->2->3->5.

说明:

给定的 n 保证是有效的。

解题思路:

1.找到倒数第n+1个节点;
2.把这个节点的next节点指向next.next。
先看数组:如果该题的数据结构不是链表而是数组的话,寻找倒数第n+1个节点时是不是就非常简单?,直接利用数据的长度和传进来的n,找到倒数第n+1个数,只是删除时,需要重新创建数组,操作稍微有些复杂,想了解详情的可以去看ArrayList的remove操作。
再看链表:链表的删除节点操作是不是很简单?只是难在如何找到倒数第n+!个节点,刚好综合数组的特点,利用数组的思想,找到倒数第n+1个节点即可,然后进行删除。

首先创建一个哑节点,并将此节点的next指向head节点,创建哑节点的目的是防止出现链表只有一个节点的情况。

方法一:创建一个指针指向head节点,先遍历一次链表,得出链表的长度lenth,然后把指针指到哑节点,再次遍历链表,让指针走length-n次,此时因为是从哑节点开始走,所以刚好在length-n次后,指针停在倒数第n+1个节点上,所以将这个节点的next节点指向next.next即可。
时间复杂度:O(n),代码:

public static ListNode removeNthFromEnd01(ListNode head, int n){//创建一个哑节点ListNode dummy = new ListNode(0);dummy.next = head;ListNode index = head;int length = 0;//第一次遍历链表,得出链表长度while (index != null){length++;index = index.next;}index = dummy;for (int i = 0; i < length - n; i++) {index = index.next;}index.next = index.next.next;return dummy.next;}

方法二:双指针,省略遍历链表得出长度的步骤。首先将两个指针都指向哑节点,然后第一个指针先往下走n+1步,以便后续找到倒数n+1个节点 ,然后两个指针同时往下走,直到第一个指针指向空节点时停止,此时刚好第二个指针指向倒数第n+1个节点,最后进行删除操作即可。
时间复杂度:O(n),代码:

public static ListNode removeNthFromEnd02(ListNode head, int n) {ListNode dummy = new ListNode(0);dummy.next = head;ListNode first = dummy;ListNode second = dummy;//使两个指针之间的距离为n+1,以便后续找到倒数n+1个节点for (int i = 0; i < n+1; i++) {first = first.next;}//两个指针同时往下走,直到第一个指针指向队尾(null)时停止,// 此时刚好第二个指针指向倒数第n+1个节点while (first != null){first = first.next;second = second.next;}second.next = second.next.next;return dummy.next;}

这篇关于力扣热搜一百题之19.删除链表的倒数第n个节点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

Redis过期删除机制与内存淘汰策略的解析指南

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

Python对PDF书签进行添加,修改提取和删除操作

《Python对PDF书签进行添加,修改提取和删除操作》PDF书签是PDF文件中的导航工具,通常包含一个标题和一个跳转位置,本教程将详细介绍如何使用Python对PDF文件中的书签进行操作... 目录简介使用工具python 向 PDF 添加书签添加书签添加嵌套书签Python 修改 PDF 书签Pytho

C#实现查找并删除PDF中的空白页面

《C#实现查找并删除PDF中的空白页面》PDF文件中的空白页并不少见,因为它们有可能是作者有意留下的,也有可能是在处理文档时不小心添加的,下面我们来看看如何使用Spire.PDFfor.NET通过C#... 目录安装 Spire.PDF for .NETC# 查找并删除 PDF 文档中的空白页C# 添加与删

SQL常用操作精华之复制表、跨库查询、删除重复数据

《SQL常用操作精华之复制表、跨库查询、删除重复数据》:本文主要介绍SQL常用操作精华之复制表、跨库查询、删除重复数据,这些SQL操作涵盖了数据库开发中最常用的技术点,包括表操作、数据查询、数据管... 目录SQL常用操作精华总结表结构与数据操作高级查询技巧SQL常用操作精华总结表结构与数据操作复制表结

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

macOS无效Launchpad图标轻松删除的4 种实用方法

《macOS无效Launchpad图标轻松删除的4种实用方法》mac中不在appstore上下载的应用经常在删除后它的图标还残留在launchpad中,并且长按图标也不会出现删除符号,下面解决这个问... 在 MACOS 上,Launchpad(也就是「启动台」)是一个便捷的 App 启动工具。但有时候,应