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

}
相关推荐
Python 老手18 分钟前
Python while 循环 极简核心讲解
java·python·算法
@Aurora.22 分钟前
优选算法【专题九:哈希表】
算法·哈希算法·散列表
爱看科技1 小时前
微美全息(NASDAQ:WIMI)研究拜占庭容错联邦学习算法,数据安全与隐私保护的双重保障
算法
qq_417129251 小时前
C++中的桥接模式变体
开发语言·c++·算法
YuTaoShao1 小时前
【LeetCode 每日一题】3010. 将数组分成最小总代价的子数组 I——(解法二)排序
算法·leetcode·排序算法
吴维炜3 小时前
「Python算法」计费引擎系统SKILL.md
python·算法·agent·skill.md·vb coding
Σίσυφος19004 小时前
PCL Point-to-Point ICP详解
人工智能·算法
玄〤4 小时前
Java 大数据量输入输出优化方案详解:从 Scanner 到手写快读(含漫画解析)
java·开发语言·笔记·算法
weixin_395448914 小时前
main.c_cursor_0202
前端·网络·算法
senijusene5 小时前
数据结构与算法:队列与树形结构详细总结
开发语言·数据结构·算法