链表——删除链表的倒数第 N 个结点

1、递归:

  1. 结束条件是节点是否为null;
  2. 然后递归调用,每次调用返回当前的倒数序号,比如说null为0,倒数第一个就是0+1,依次加1;
  3. 当前函数返回的整数表示当前的节点是倒数第几个;
  4. 返回到上一级后,判断返回的序列号;比如说我们要删除倒数第二个,如果返回倒数第三层的x=2,就删除当前元素的下一个元素;(因为返回的x一定是下一层的序号)
  5. 需要注意的是:
    1. 有可能删除第一个元素,但是第一个元素没有前一个节点,所以需要添加一个虚拟节点;
java 复制代码
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
       ListNode demy = new ListNode();
       demy.next = head;
        demo(demy,n);
        return demy.next;
    }

    public int demo(ListNode node,int n){
         if(node==null){
            return 0;
        }
       int x =  demo(node.next,n);
       if(x==n){
        node.next= node.next.next;
       }
       return x+1;
    }
}

2、快慢指针法

  1. 因为可能删除第一个节点,所以需要一个虚拟节点,
  2. 删除元素,需要当前删除元素的上一个节点来操作;
  3. 比如说:删除倒数第二个元素,那就需要找到倒数第3个元素;
  4. 快慢指针,那就是让快指针先走三步;然后两个指针一起走;
  5. 当快指针走到null时,正好慢指针就是到倒数第三个元素;
  6. 然后使得left.next=left.next.next;
java 复制代码
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode dummy  = new ListNode();
        dummy.next = head;
        ListNode left = dummy;
        ListNode right =dummy;
        int i =0;
        while(i<n){
            right = right.next;
            i++;
        }
        while(right.next !=null){
            left   = left.next;
            right = right.next;
        }
        left.next =left.next.next;
        return dummy.next;

    }
}
相关推荐
晚枫歌F2 小时前
最小堆定时器
数据结构·算法
嫩萝卜头儿3 小时前
2 - 复杂度收尾 + 链表经典OJ
数据结构·算法·链表·复杂度
样例过了就是过了4 小时前
LeetCode热题100 分割等和子集
数据结构·c++·算法·leetcode·动态规划
木木_王4 小时前
嵌入式Linux学习 | 数据结构 (Day05) 栈与队列详解(原理 + C 语言实现 + 实战实验 + 易错点剖析)
linux·c语言·开发语言·数据结构·笔记·学习
北顾笙9804 小时前
day38-数据结构力扣
数据结构·算法·leetcode
m0_629494734 小时前
LeetCode 热题 100-----14.合并区间
数据结构·算法·leetcode
@小码农5 小时前
2026年3月Scratch图形化编程等级考试一级真题试卷
开发语言·数据结构·c++·算法
_日拱一卒7 小时前
LeetCode:226翻转二叉树
数据结构·算法·leetcode
风筝在晴天搁浅8 小时前
手撕快速排序
数据结构
图码8 小时前
矩阵数据结构入门指南:声明、初始化与基本操作
运维·数据结构·线性代数·算法·矩阵