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

方法一:递归

思路:

利用递归思想遍历链表,然后从链表最后一个元素开始判断是不是题目传来的要删除的。如果是就找到上一个节点来删除。

java 复制代码
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode s=new ListNode(-1,head);
        inte(s,n);
        return s.next;
    }
    public int  inte(ListNode head, int n){
      if(head==null){
        return 0;
      }
    int  count= inte(head.next,n);
    if(count==n){
        head.next=head.next.next;
    }
    return count+1;
    }
}

方法二:双指针

//双指针,要删除第几个元素就让一个指针提前移动n+1;

//然后两个指针同时移动直到找到要删除的节点

java 复制代码
class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
       //双指针,要删除第几个元素就让一个指针提前移动n+1;
       //然后两个指针同时移动直到找到要删除的节点
       ListNode s= new ListNode(-1,head);
       ListNode p1=s;
       ListNode p2=s;
       //先移动一个指针
       for(int i=0;i<n+1;i++){
        p2=p2.next;
       }
      while(p2 !=null){
        p1=p1.next;
        p2=p2.next;
        }
       p1.next=p1.next.next;
       return s.next;
    }

}
相关推荐
Wenhao.3 小时前
LeetCode 合并K个升序链表
leetcode·链表·golang
代码不停4 小时前
Java前缀和算法题目练习
java·开发语言·算法
courniche4 小时前
分组密码常见结构简介
算法·密码学
涤生z4 小时前
list.
开发语言·数据结构·c++·学习·算法·list
茜茜西西CeCe4 小时前
数字图像处理-图像增强(2)
人工智能·算法·计算机视觉·matlab·数字图像处理·图像增强·陷波滤波器
薰衣草23335 小时前
hot100练习-11
算法·leetcode
地平线开发者5 小时前
征程 6 | 工具链如何支持 Matmul/Conv 双 int16 输入量化?
人工智能·算法·自动驾驶
甄心爱学习5 小时前
数值计算-线性方程组的迭代解法
算法
stolentime5 小时前
SCP2025T2:P14254 分割(divide) 题解
算法·图论·组合计数·洛谷scp2025