leetcode19:删除链表倒数第n个节点

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

**进阶:**你能尝试使用一趟扫描实现吗?

步骤 1:问题分析

问题性质

  • 给定一个单链表,需要删除倒数第 n 个节点,并返回链表的头节点。
  • 删除操作需要在链表中进行节点的连接调整。

输入输出条件

  • 输入:链表的头节点 head 和一个整数 n(表示倒数第 n 个节点)。
  • 输出:删除指定节点后的链表头节点。

限制

  • 链表节点数 sz[1, 30] 范围内。
  • 0 <= Node.val <= 100
  • 1 <= n <= sz

边界条件

  • n == 1sz == 1:链表仅有一个节点,删除后链表为空。
  • n == sz:删除第一个节点,调整头节点即可。
  • 1 < n < sz:删除链表中间节点,需重新调整连接。

步骤 2:解题思路

由于要求一次遍历 删除倒数第 n 个节点,使用双指针法(或称"快慢指针")是一个有效的方法。

算法设计思路

  1. 创建虚拟头节点

    • 使用一个虚拟节点 dummy 指向 head,简化删除操作的边界情况,例如删除第一个节点时可以避免特殊处理。
  2. 初始化双指针

    • 初始化两个指针 firstsecond 都指向 dummy
  3. 移动 first 指针

    • first 指针向前移动 n + 1 步,使 firstsecond 之间有 n 个节点的距离。
  4. 移动 firstsecond 指针

    • 同时移动 firstsecond,直到 first 到达链表末尾。
    • 此时 second 指向倒数第 n + 1 个节点(即要删除节点的前一个节点)。
  5. 删除节点

    • 调整 second->next 指向 second->next->next,跳过目标节点,完成删除。
  6. 返回结果

    • 返回 dummy->next,即删除指定节点后的链表头。

复杂度分析

  • 时间复杂度:O(sz),仅需一次遍历。
  • 空间复杂度:O(1),使用常量级别的辅助指针。

步骤 3:C++代码实现

代码详解

  1. 初始化虚拟节点

    • 使用 dummy 节点指向 head,处理边界情况(如删除头节点)。
  2. 前进 first 指针

    • first 指针前进 n + 1 步,这样 firstsecond 间隔 n 个节点。
  3. 双指针同步前进

    • first 到达链表末尾时,second 位于要删除节点的前一个节点。
  4. 删除节点

    • 调整 second->next,跳过目标节点,完成删除。
  5. 返回结果

    • dummy->next 即为新链表的头节点。

步骤 4:启发与算法优化

  1. 双指针法的灵活性:双指针法在链表操作中非常高效,尤其是在找倒数节点、判断环、合并链表等场景中可以实现一趟扫描。这种方法不仅节省时间,还避免了不必要的空间浪费。

  2. 虚拟节点的优势 :虚拟头节点 dummy 是链表题中的常用技巧,通过 dummy 可以简化删除头节点的处理,无需特意判断头节点的删除情况。

  3. 算法优化:通过一次遍历解决倒数问题,比传统的两次遍历(先计算链表长度,再定位删除节点)更高效,避免了不必要的额外计算。


步骤 5:实际应用及场景分析

应用场景: 删除链表的倒数节点的算法可以应用在日志系统、队列管理系统、缓存控制等需要删除最近使用的数据场景。例如:

  • 缓存数据管理:在缓存数据中,可以通过链表来维护最近最少使用的数据记录。如果某些数据长期未被访问且缓存超出容量,可以删除最不常用的数据(即倒数位置的数据)。

应用示例 : 在一项日志管理系统中,需要按顺序记录用户的行为记录。系统可使用链表存储日志记录,保持其顺序。如果系统检测到日志条目数超出限制,可以删除倒数的第 n 条日志记录以优化存储空间。

相关推荐
青青丘比特10 分钟前
STL.string(下)
开发语言·c++
c1assy14 分钟前
DP动态规划+贪心题目汇总
数据结构·算法·leetcode·贪心算法·动态规划
jjjxxxhhh12317 分钟前
C++ 模板是为了解决啥问题
开发语言·c++·算法
c++初学者ABC22 分钟前
GESP2级2403 小杨的日字矩阵
c++·算法
大写-凌祁42 分钟前
2024国赛A题第一问
线性代数·算法·机器学习·数学建模
代码小将1 小时前
PTA数据结构编程题7-1最大子列和问题
数据结构·c++·笔记·学习·算法
HackKong1 小时前
高校网络安全_网络安全之道
java·网络·c++·python·学习·web安全·黑客技术
BUG制造机.1 小时前
修炼之道 ---其四
linux·c++
pk_xz1234561 小时前
R 和 Origin 完成细菌 OTU 表、土壤理化性质数据的微生物 Beta 多样性分析
算法·机器学习·r语言
Ning_.1 小时前
力扣第116题:填充每个节点的下一个右侧节点指针 - C语言解法
c语言·算法·leetcode