leetcode刷题(剑指offer) 19.删除链表的倒数第N个节点

19.删除链表的倒数第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

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

题解

本题的解题思路是使用两个指针,在此我定义三个指针分别为frontbackpre 。让front 先向前移动n格,然后再让frontback 同时向前移动,当front 遍历到最后一个的时候,back 指针指向的元素就是链表中的倒数第n个, preback 的前一个,利用pre.next = back.next实现删除逻辑。

但本题存在一个注意点,就是如果只有一个节点,只是删除第一个,那么就需要删除头节点,这就涉及到了头节点的改变,因此还是用到了之前 删除排序链表中的重复元素Ⅱ 中提到的技巧,创建一个dummy节点用来指向头节点,最后返回dummy.next

举个栗子,链表为[1], n等于1。如下:

使用这种方案,只需要遍历依次链表,即可完成删除,代码实现如下:

java 复制代码
package com.offer;

import com.offer.leetcode.datastruct.ListNode;
import com.offer.leetcode.datastruct.ListNodeUtils;

public class _19删除链表的倒数第N个节点 {
    public static void main(String[] args) {
        ListNode head = ListNodeUtils.createList(new int[]{1});
        ListNodeUtils.printListNode(head);
        head = removeNthFromEnd(head, 1);
        ListNodeUtils.printListNode(head);
    }

    public static ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode front = head;
        ListNode back = head;
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        ListNode pre = dummy;
        // front向前移动n格
        while (front != null && n > 0) {
            front = front.next;
            n--;
        }
        while (front != null) {
            pre = back;
            back = back.next;
            front = front.next;
        }
        pre.next = back.next;
        // back即为需要删除的节点
        return dummy.next;
    }
}
相关推荐
Yzzz-F2 小时前
Problem - 2205D - Codeforces
算法
智者知已应修善业2 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn2 小时前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室3 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星3 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿4 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨4 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
晨曦夜月5 小时前
map与unordered_map区别
算法·哈希算法
图码5 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
handler015 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法