快慢指针删除链表的第N个元素——力扣19

给你一个链表,删除链表的倒数第 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]

分析:

想要删除倒数第n个节点,我们必须找到倒数第n+1个节点,即倒数第n节点的前驱节点

思路 :

创建两个指针 fast和slow,让fast指针先走n+1步,然后slow和fast一起移动,然后当fast移动到最后一个节点时,slow此时指到倒数n+1节点,此时便可以执行删除操作

java 复制代码
 public ListNode removeNthFromEnd(ListNode head, int n) {
        if(head==null){return null;}
         ListNode duty=new ListNode(0);
         duty.next=head;
         ListNode fast=duty;   
         ListNode slow=duty;
         for(int i=0;i<=n;i++){
             fast=fast.next;
         }
         while(fast!=null){
             fast=fast.next;
             slow=slow.next;

         }
         slow.next=slow.next.next;
         return duty.next;
    }

之所以new一个duty让他的后继节点指向head,是因为有可能存在head节点被删除的情况,此时如果直接返回head会出现指针指空的问题,返回duty.next可以有效解决空指针问题

相关推荐
学传打活2 天前
古代汉语是源,现代汉语是流,源与流一脉相承。
微信公众平台·1024程序员节·汉字·中华文化
学传打活7 天前
【边打字.边学昆仑正义文化】_19_星际生命的生存状况(1)
微信公众平台·1024程序员节·汉字·昆仑正义文化
unable code14 天前
[HNCTF 2022 WEEK2]ez_ssrf
网络安全·web·ctf·1024程序员节
unable code15 天前
[NISACTF 2022]easyssrf
网络安全·web·ctf·1024程序员节
unable code16 天前
BUUCTF-[第二章 web进阶]SSRF Training
网络安全·web·ctf·1024程序员节
开开心心就好17 天前
进程启动瞬间暂停工具,适合调试多开
linux·运维·安全·pdf·智能音箱·智能手表·1024程序员节
仰泳之鹅18 天前
【51单片机】第一课:单片机简介与软件安装
单片机·嵌入式硬件·51单片机·1024程序员节
海海不瞌睡(捏捏王子)19 天前
C#知识点概要
java·开发语言·1024程序员节
小浣熊熊熊熊熊熊熊丶20 天前
飞牛NAS 安装 Teslamate 教程(docker版)
1024程序员节
程高兴20 天前
模糊PID控制的永磁同步电机矢量控制系统-SIMULINK
matlab·1024程序员节