在O(1)的时间内删除结点

2024-08-25 07:18
文章标签 时间 删除 结点

本文主要是介绍在O(1)的时间内删除结点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

剑指Offer_13: 在 O(1) O ( 1 ) 的时间内删除结点


2018/05/14 星期一

题目: 给定单项链表的头指针和一个结点指针,定义一个函数在 O(1) O ( 1 ) ​ 的时间删除该结点。链表结点和函数的定义如下:

class ListNode {int data;ListNode nextNode;
}
public void deleteNode(ListNode head, ListNode deListNode)

思考三分钟。。。。

在链表中删除一个结点

在单链表中删除一个结点,最简单的方法无疑就是从链表的头结点开始,顺序遍历查找要删除的结点,并在链表中删除该结点。

  • 上图(a)中表示一个单链表
  • 上图(b)中,表示顺序遍历删除i结点。删除i结点之前,先从头结点开始遍历到i前面的一个结点h,然后把h结点的指针指向i的下一个节点j,再删除节点i(常规思路复杂度 O(n) O ( n ) )。
  • 上图(c)中,把结点j中的内容复制到结点i中,再把i中的指针指向节点j的指针。这种方法不用遍历i结点前面的元素。时间复杂度为 O(1) O ( 1 )

基于图(c)的思路中还需要考虑一个问题,如果更新的节点位于链表的尾部(尾结点),怎么办,它没有下一个节点?这时候只能通过顺序遍历查找(图(b)中表示的方法)。如果我们有一个节点,删除的位置即是头结点也是尾结点,当我们在删除的时候除了删除节点还是将头结点置为null。完整代码如下:

public void deleteNode(ListNode head, ListNode deListNode) {if (deListNode == null || head == null) {return;}// 如果删除头结点if (head == deListNode) {head = null;} else {// 如果删除结点为尾结点if (deListNode.nextNode == null) {ListNode pointListNode = head;while (pointListNode.nextNode.nextNode != null) {pointListNode = pointListNode.nextNode;}pointListNode.nextNode = null;} else {deListNode.data = deListNode.nextNode.data;deListNode.nextNode = deListNode.nextNode.nextNode;}}
}

算法的时间复杂度:对于n-1个非尾结点而言,我们是可以在 O(1) O ( 1 ) 的时间内完成操作;对于尾结点我们仍然需要顺序查找,时间复杂度为 O(n) O ( n ) 。总的平均时间复杂度是 [(n1)O(1)+O(n)]n [ ( n − 1 ) ∗ O ( 1 ) + O ( n ) ] n ,结果还是 O(1) O ( 1 )

上述的代码并不是完美的代码,它基于一个假设,那就是要删除的结点存在链表当中。

测试用例:

  1. 功能测试:删除多个结点链表的中间结点,头结点,尾结点等;从只有一个结点的链表中删除唯一结点。
  2. 特殊输入测试:

这篇关于在O(1)的时间内删除结点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

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

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

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

SQL Server清除日志文件ERRORLOG和删除tempdb.mdf

《SQLServer清除日志文件ERRORLOG和删除tempdb.mdf》数据库再使用一段时间后,日志文件会增大,特别是在磁盘容量不足的情况下,更是需要缩减,以下为缩减方法:如果可以停止SQLSe... 目录缩减 ERRORLOG 文件(停止服务后)停止 SQL Server 服务:找到错误日志文件:删除

Python如何获取域名的SSL证书信息和到期时间

《Python如何获取域名的SSL证书信息和到期时间》在当今互联网时代,SSL证书的重要性不言而喻,它不仅为用户提供了安全的连接,还能提高网站的搜索引擎排名,那我们怎么才能通过Python获取域名的S... 目录了解SSL证书的基本概念使用python库来抓取SSL证书信息安装必要的库编写获取SSL证书信息

mysql删除无用用户的方法实现

《mysql删除无用用户的方法实现》本文主要介绍了mysql删除无用用户的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 1、删除不用的账户(1) 查看当前已存在账户mysql> select user,host,pa

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、