链表之leetcode19:删除链表的倒数第N个结点

删除链表的倒数第N个结点
题目描述

给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

提示:

  • 链表中的结点的数目为sz
  • 1 <= sz <= 30
  • 0 <= Node.val <= 100
  • 1 <= n <= sz
代码
java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        // 使用一个虚拟头结点进行统一处理
        ListNode dummyHead = new ListNode();
        dummyHead.next = head;
        
        // 可以使用两个指针,先让快指针往后移动n个位置,然后慢指针和快指针同时移动,直到快指针指向null,此时慢指针指向的是倒数第n个元素
        // 由于要删除元素,所以我们需要指向要删除元素的前一个元素
        // 所以可以将快指针再往后移动一个元素,也就是总共移动n+1个位置
        ListNode slow = dummyHead;
        ListNode quick = dummyHead;
        n++;
        while(n-- != 0) {
            quick = quick.next;
        }
        // 快慢指针同时移动
        while(quick != null) {
            slow = slow.next;
            quick = quick.next;
        }
        slow.next = slow.next.next;
        return dummyHead.next;
    }
}
相关推荐
烬羽4 分钟前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构
YHL14 分钟前
🚀从零理解树与二叉树 —— 概念、实现与遍历
前端·javascript·数据结构
JieE21243 分钟前
JS 到底有多少种数据类型?从ECMA规范到内存本质,一文彻底搞懂
javascript·数据结构·面试
努力努力再努力wz1 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
八解毒剂1 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
Darling噜啦啦3 小时前
JavaScript 数组深度解析:从纯函数到二维数组陷阱,一文吃透前端数据结构核心
前端·javascript·数据结构
不会就选b4 小时前
数据结构之链表OJ题(中)
数据结构·链表
J2虾虾5 小时前
C语言 typedef 用法
c语言·数据结构·算法
budingxiaomoli5 小时前
二叉树中的深搜
数据结构
断点之下5 小时前
数据结构从零开始④:堆——一种特殊的完全二叉树(附堆排序、TopK问题)
数据结构