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;
    }

}
相关推荐
地平线开发者10 小时前
J6B vio scenario sample
算法
BothSavage1 天前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn1 天前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽1 天前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说2 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰2 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术2 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六2 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程