(leetcode学习)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

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

不是很懂为什么大佬会用一个假的头节点,防止快指针为NULL吗?

cpp 复制代码
ListNode* removeNthFromEnd(ListNode* head, int n) {
        ListNode* fast = head;
        ListNode* slow = head;
        while(n--) fast=fast->next;
        if(fast == NULL) return head->next;

        while(fast->next != NULL){
            fast = fast->next;
            slow = slow->next;
        }
        slow->next = slow->next->next;
        return head;
    }
相关推荐
迈巴赫车主9 分钟前
求最大公约数-欧几里得算法(辗转相除法)
算法·最大公约数
lxl130722 分钟前
C++算法(15)BFS_FloodFill
算法·宽度优先
小王C语言25 分钟前
【基础IO】————简单设计一下libc库
前端·数据结构·算法
亦复何言??26 分钟前
BeyondMimic 论文解析
人工智能·算法·机器人
WolfGang00732130 分钟前
代码随想录算法训练营 Day20 | 回溯算法 part02
算法
YXXY31333 分钟前
前缀和算法
算法
客卿12333 分钟前
滑动窗口--模板
java·算法
_日拱一卒1 小时前
LeetCode:滑动窗口的最大值
数据结构·算法·leetcode
codeの诱惑1 小时前
推荐算法(一):数学基础回顾——勾股定理与欧氏距离
算法·机器学习·推荐算法
落樱弥城1 小时前
Vulkan Compute 详解
算法·ai·图形学