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

}
相关推荐
一只侯子16 小时前
Face AE Tuning
图像处理·笔记·学习·算法·计算机视觉
jianqiang.xue17 小时前
别把 Scratch 当 “动画玩具”!图形化编程是算法思维的最佳启蒙
人工智能·算法·青少年编程·机器人·少儿编程
不许哈哈哈17 小时前
Python数据结构
数据结构·算法·排序算法
J***793918 小时前
后端在分布式系统中的数据分片
算法·哈希算法
Dream it possible!19 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树中第 K 小的元素(86_230_C++_中等)
c++·leetcode·面试
sin_hielo19 小时前
leetcode 2872
数据结构·算法·leetcode
dragoooon3420 小时前
[优选算法专题八.分治-归并 ——NO.49 翻转对]
算法
AI科技星20 小时前
为什么宇宙无限大?
开发语言·数据结构·经验分享·线性代数·算法
Zero-Talent21 小时前
位运算算法
算法
不穿格子的程序员21 小时前
从零开始刷算法——双指针-三数之和&接雨水
算法·双指针