LeetCode:19. 删除链表的倒数第 N 个结点

简介

题目链接:https://leetcode.cn/problems/remove-nth-node-from-end-of-list/description/

解决方式:链表 + 双指针

这是作者学习众多大神的思路进行解题的步骤,很推荐大家解题的时候去看看题解里面大佬们的思路、想法!

推荐看自在飞花(141)、灵茶山艾府大佬的讲解。

双指针

解题思路:此题略有不同,由于可能存在链表头节点就是倒数第 n 个节点的情况,所以我们需要在双指针的基础上在创建一个伪头节点,方便后续可能删除头节点。再者,此题双指针并不是一般上的一块一慢,而是固定一个长度。这样迭代到终止条件时,后节点就可以指向倒数第 n 个节点或者倒数第 n 个节点的上一个节点。

java 复制代码
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        // 伪头节点,解决删除链表头节点的情况
        ListNode t = new ListNode(0,head);
        ListNode pre = t;
        ListNode cur = t;
        // 前驱节点往后移动 n 次
        while(n-- > 0){
            pre = pre.next;
        }
        // 两节点保持相同的距离向后移动
        while(pre.next != null){ 
        		 // 防止后节点直接指向倒数第 n 个节点
        		 // 若想直接指向倒数第 n 个节点,可以 pre != null。
            pre = pre.next;
            cur = cur.next;
        }
        // 此时,后节点指向倒数第 n 个节点的前一个节点
        // 移除倒数第 n 个节点
        cur.next = cur.next.next;
        // 返回结果
        return t.next;
    }
}
相关推荐
weixin_307779132 小时前
OpenClaw-CN 安全增强方案:从理念到落地的全面剖析
开发语言·人工智能·算法·安全·语言模型
CoovallyAIHub2 小时前
Agency-Agents(52k+ Stars):140+ 个角色模板,让 AI 编程助手变成一支专业团队
前端·算法·编程语言
nananaij2 小时前
【LeetCode-05 好数对的数目 python解法】
python·算法·leetcode
季远迩2 小时前
73.矩阵置零(中等)
算法
做一个码农都是奢望2 小时前
计算机控制系统课程CH3:数字控制系统闭环响应分析与 MATLAB 实现
人工智能·算法·matlab
爱玩亚索的程序员2 小时前
算法入门(三)学会用matplotlib画图
算法·matplotlib
一叶落4382 小时前
LeetCode 6. Z 字形变换(C语言详解)
c语言·数据结构·算法·leetcode
啊董dong2 小时前
noi-2026年3月17号作业
数据结构·c++·算法
2401_874732532 小时前
泛型编程与STL设计思想
开发语言·c++·算法