算法(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)

相关推荐
Student_Zhang5 分钟前
推荐一个数据加密的框架GMObjc(iOS)
前端·算法·github
还是鼠鼠1 小时前
Node.js 模块化概念详细介绍
前端·javascript·vscode·node.js·web
TE-茶叶蛋1 小时前
前端npm包- CropperJS
前端·npm·node.js
正小安1 小时前
前端高阶面试题·每日一题
前端·javascript·面试题
Useee2 小时前
DAY33 贪心算法Ⅱ
算法·贪心算法
酷酷的崽7982 小时前
【栈数据结构应用解析:常见算法题详细解答】—— Leetcode
数据结构·算法·leetcode
胡桃夹夹子2 小时前
vue 仿deepseek前端开发一个对话界面
前端·javascript·vue.js
Book_熬夜!2 小时前
数据结构——环形数组
javascript·数据结构·算法
奋斗者1号2 小时前
Python 中 lambda 表达式、推导式和其他函数用法对比
开发语言·python·算法
returnShitBoy5 小时前
前端面试:如何实现预览 PDF 文件?
前端·pdf