【算法系列-链表】删除链表的倒数第N个结点

【算法系列-链表】删除链表的倒数第N个结点

文章目录

  • 【算法系列-链表】删除链表的倒数第N个结点
    • [1. 算法分析🛸](#1. 算法分析🛸)
    • [2. 模拟解决问题](#2. 模拟解决问题)
      • [2.1 思路分析🎯](#2.1 思路分析🎯)
      • [2.2 代码示例🌰](#2.2 代码示例🌰)
    • [3. 双指针(快慢指针)解决问题](#3. 双指针(快慢指针)解决问题)
      • [3.1 思路分析🎯](#3.1 思路分析🎯)
      • [3.2 代码示例🌰](#3.2 代码示例🌰)

【题目链接】 LeetCode 19 删除链表的倒数第N个结点

1. 算法分析🛸

这道题的关键点在于找到删除节点的位置,而题目提供给我们的是倒数第n个节点的位置,对此我们需要通过操作找到这倒数第n个节点,这里我提供两种方法:模拟 & 双指针

2. 模拟解决问题

2.1 思路分析🎯

通过一轮循环遍历来获取链表的长度 size ,而 size - n

的位置就是目标删除节点的前一个节点,通过它来删除目标节点即可

2.2 代码示例🌰

java 复制代码
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode vhead = new ListNode();
        vhead.next = head;
        ListNode cur = vhead;
        int size = 0;
        while (cur != null && cur.next != null) {
            cur = cur.next;
            size++;
        }
        cur = vhead;
        for (int i = 0;i < size - n;i++) {
            cur = cur.next;
        }
        cur.next = cur.next.next;
        return vhead.next;
    }
}

3. 双指针(快慢指针)解决问题

3.1 思路分析🎯

这里使用了双指针 (快慢指针)来解决问题,定义快慢指针先指向虚拟头节点,之后让 fast 先走 n + 1 步(这里比n 多走一步是为了让slow到达删除节点的前一个节点,方便我们进行节点删除操作),后让slow 和 fast 同时往后遍历,直到 fast 指向空,此时slow所处位置的下一个节点就是目标删除节点,进行删除操作即可

通过图解大家能更好理解:

3.2 代码示例🌰

java 复制代码
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode vhead = new ListNode();
        vhead.next = head;
        ListNode fast = vhead;;
        ListNode slow = vhead;
        for (int i = 0;i <= n;i++) {
            fast = fast.next;
        }
        while (fast != null) {
            fast = fast.next;
            slow = slow.next;
        }
        slow.next = slow.next.next;
        return vhead.next;
    }
}

以上便是对删除链表的倒数第N个结点类型题的介绍了!!后续还会继续分享其它算法系列内容,如果这些内容对大家有帮助的话请给一个三连关注吧💕( •̀ ω •́ )✧( •̀ ω •́ )✧✨

相关推荐
im_AMBER1 小时前
Leetcode 78 识别数组中的最大异常值 | 镜像对之间最小绝对距离
笔记·学习·算法·leetcode
鼾声鼾语2 小时前
matlab的ros2发布的消息,局域网内其他设备收不到情况吗?但是matlab可以订阅其他局域网的ros2发布的消息(问题总结)
开发语言·人工智能·深度学习·算法·matlab·isaaclab
其美杰布-富贵-李2 小时前
HDF5文件学习笔记
数据结构·笔记·学习
LYFlied2 小时前
【每日算法】LeetCode 25. K 个一组翻转链表
算法·leetcode·链表
Swizard2 小时前
别再迷信“准确率”了!一文读懂 AI 图像分割的黄金标尺 —— Dice 系数
python·算法·训练
s09071362 小时前
紧凑型3D成像声纳实现路径
算法·3d·声呐·前视多波束
可爱的小小小狼2 小时前
算法:二叉树遍历
算法
d111111111d3 小时前
在STM32函数指针是什么,怎么使用还有典型应用场景。
笔记·stm32·单片机·嵌入式硬件·学习·算法
明洞日记3 小时前
【数据结构手册008】STL容器完全参考指南
开发语言·数据结构·c++
kingmax542120084 小时前
《数据结构C语言:单向链表-链表基本操作(尾插法建表、插入)》15分钟试讲教案【模版】
c语言·数据结构·链表