【算法】在 O(1) 时间内删除链表节点

1.概述

解题思路

① 如果该节点不是尾节点,那么可以直接将下一个节点的值赋给该节点,然后令该节点指向下下个节点,再删除下一个节点,时间复杂度为 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, 

相关推荐

  1. 剑指offer面试题13 O(1)时间删除结点

    2024-07-12 10:06:02       54 阅读
  2. 删除的重复节点

    2024-07-12 10:06:02       38 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-12 10:06:02       66 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-12 10:06:02       70 阅读
  3. 在Django里面运行非项目文件

    2024-07-12 10:06:02       57 阅读
  4. Python语言-面向对象

    2024-07-12 10:06:02       68 阅读

热门阅读

  1. Mybatis SQL注解使用场景

    2024-07-12 10:06:02       16 阅读
  2. python 缩放照片

    2024-07-12 10:06:02       24 阅读
  3. 谈一谈徒劳的坐地收益的副业问题

    2024-07-12 10:06:02       26 阅读
  4. Milvus Cloud向量数据库:优势解析与深度应用探索

    2024-07-12 10:06:02       21 阅读
  5. MyBatis与数据库交互的四种方法详解

    2024-07-12 10:06:02       18 阅读
  6. uni-app 扫描二维码获取信息功能

    2024-07-12 10:06:02       20 阅读
  7. 设计模式Base

    2024-07-12 10:06:02       21 阅读