算法(TS):删除链表的倒数第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]

提示:

  1. 链表中结点的数目为 sz
  2. 1 <= sz <= 30
  3. 0 <= Node.val <= 100
  4. 1 <= n <= sz

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

解法

定义两个指针,fast 和 low,fast 先走 n 步,之后 low 和 fast 每一次都各走一步,直到 fast.next 为null,此时 删除 low 的下一个节点就是该删除的。这里要特殊处理删除头节点

vbscript 复制代码
/**
 * Definition for singly-linked list.
 * class ListNode {
 *     val: number
 *     next: ListNode | null
 *     constructor(val?: number, next?: ListNode | null) {
 *         this.val = (val===undefined ? 0 : val)
 *         this.next = (next===undefined ? null : next)
 *     }
 * }
 */

function removeNthFromEnd(head: ListNode | null, n: number): ListNode | null {
    if (head === null) return null

    let fast = head
    let low = null

    let i = 1

    while(i < n) {
        fast = fast.next
        i++
    }

    if (fast && fast.next) {
        while(fast.next) {
            fast = fast.next
            low = low ? low.next: head
        }
        // 删除 low 的下一个
        low.next = low.next.next
        return head
    } else { // 删除第一个节点
        return head.next
    }
};

时间复杂度O(n),空间负责度O(1)

相关推荐
孟祥_成都几秒前
【全网最通俗!新手到AI全栈开发必读】 AI 是如何进化到大模型的
前端·人工智能·全栈
牛奶24 分钟前
AI辅助开发的基础概念
前端·人工智能·ai编程
摸鱼的春哥27 分钟前
Agent教程15:认识LangChain,Agent框架的王(上)
前端·javascript·后端
明月_清风1 小时前
自定义右键菜单:在项目里实现“选中文字即刻生成新提示”
前端·javascript
明月_清风1 小时前
告别后端转换:高质量批量导出实战
前端·javascript
刘发财6 小时前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
牛奶9 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶9 小时前
前端人为什么要学AI?
前端·人工智能·ai编程
地平线开发者10 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮11 小时前
大模型连载2:初步认识 tokenizer 的过程
算法