博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在 O(1) 时间内删除链表节点
阅读量:4212 次
发布时间:2019-05-26

本文共 856 字,大约阅读时间需要 2 分钟。

解题思路① 如果该节点不是尾节点,那么可以直接将下一个节点的值赋给该节点,然后令该节点指向下下个节点,再删除下一个节点,时间复杂度为 O(1)。② 如果链表只有一个节点,那么直接② 否则,就需要先遍历链表,找到节点的前一个节点,然后让前一个节点指向 null,时间复杂度为 O(N)。综上,如果进行 N 次操作,那么大约需要操作节点的次数为 N-1+N=2N-1,其中 N-1 表示 N-1 个不是尾节点的每个节点以 O(1) 的时间复杂度操作节点的总次数,N 表示 1 个尾节点以 O(N) 的时间复杂度操作节点的总次数。(2N-1)/N ~ 2,因此该算法的平均时间复杂度为 O(1)。
public ListNode deleteNode(ListNode head, ListNode tobeDelete) {    if (head == null || tobeDelete == null)        return null;    if (tobeDelete.next != null) {        // 要删除的节点不是尾节点        ListNode next = tobeDelete.next;        tobeDelete.val = next.val;        tobeDelete.next = next.next;    } else {        if (head == tobeDelete)             // 只有一个节点            head = null;        else {            ListNode cur = head;            while (cur.next != tobeDelete)                cur = cur.next;            cur.next = null;        }    }    return head;}

 

转载地址:http://sdkmi.baihongyu.com/

你可能感兴趣的文章
mysqldump备份及结合binlog日志恢复的全过程
查看>>
SQL Server 查找占用CUP内存的SQL
查看>>
ms sql server缓存清除与内存释放
查看>>
怎样使用命令来结束进程
查看>>
三款免费实用的本地文件夹同步/备份软件推荐 (SyncToy/FreeFileSync/Compare Advance)
查看>>
查找库中某个表的字段情况
查看>>
CREATE TABLE A LIKE B
查看>>
bs调用另一个vbs的函数
查看>>
mysql的“Got error 28 from storage engine”错误
查看>>
jdk安装
查看>>
存档数据迁移
查看>>
查看表对应的文件组
查看>>
压缩表
查看>>
SQL Server 分布式事务
查看>>
存在防火墙时MSDTC的运行配置
查看>>
SQL Server未将服务器 DBSERVER 配置为用于 DATA ACCESS
查看>>
拦截数据库增删改操作
查看>>
10倍以上提高Pentaho Kettle的MySQL写入速度
查看>>
MySQL的Galera Cluster配置说明
查看>>
SQL 添加链接服务器
查看>>