首页 > 其他分享 >删除链表的倒数第N个节点

删除链表的倒数第N个节点

时间:2022-09-05 15:46:47浏览次数:95  
标签:slow cur fast Next 链表 节点 倒数第

删除链表的倒数第N个节点

给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。

进阶:你能尝试使用一趟扫描实现吗?

示例 1:

19.删除链表的倒数第N个节点

输入:head = [1,2,3,4,5], n = 2 输出:[1,2,3,5] 示例 2:

输入:head = [1], n = 1 输出:[] 示例 3:

输入:head = [1,2], n = 1 输出:[1]

#思路

《代码随想录》算法公开课:链表遍历学清楚! | LeetCode:19.删除链表倒数第N个节点 (opens new window),相信结合视频在看本篇题解,更有助于大家对链表的理解。

双指针的经典应用,如果要删除倒数第n个节点,让fast移动n步,然后让fast和slow同时移动,直到fast指向链表末尾。删掉slow所指向的节点就可以了。

思路是这样的,但要注意一些细节。

分为如下几步:

img

  • fast首先走n + 1步 ,为什么是n+1呢,因为只有这样同时移动的时候slow才能指向删除节点的上一个节点(方便做删除操作),如图: img
  • fast和slow同时移动,直到fast指向末尾,如题: img
  • 删除slow指向的下一个节点,如图: img
package main

func removeNthFromEnd(head *ListNode, n int) *ListNode {

   dummy:=&ListNode{
      Val: 0,
      Next: nil,

   }
   cur:=dummy
   slow:=dummy
   dummy.Next=head
   for ;n>0;n-- {
      cur=cur.Next
   }
   cur=cur.Next
   for cur!=nil {
      slow=slow.Next
      cur=cur.Next
   }
   slow.Next=cur.Next.Next
   return dummy.Next

   
}

标签:slow,cur,fast,Next,链表,节点,倒数第
From: https://www.cnblogs.com/suehoo/p/16658378.html

相关文章

  • leetcode-链表-19
    /***<p>给你一个链表,删除链表的倒数第&nbsp;<code>n</code><em>&nbsp;</em>个结点,并且返回链表的头结点。</p>**<p>&nbsp;</p>**<p><strong>示例1:</strong><......
  • jenkins新增salve节点
     步骤如下:1、登录到jenkins主页,点击ManagerJenkins2、选择ManageNodes,点击进入配置页面3、新建node节点4、配置node节点5、新建目录jenkins-workspaces目录......
  • Problem P07. [算法课分治] 链表排序(归并排序)
    采用归并算法,先将一个链表分成两个链表,分到不能再分,然后再将已经排好序的链表有序地归并起来。主要问题:1.一个子链表如何分成两个。2.释放空间的问题(没有实现)#inclu......
  • 数据结构与算法学习笔记———链表(Linked List)
    链表(LinkedList)#该篇笔记转自【Python】python链表_小周ipython的博客-CSDN博客_python链表简介链表(LinkedList):是一种线性表数据结构。他是用一组任意的存储单元(可......
  • OpenHarmony中的HDF单链表及其迭代器
    概念为了性能考虑,嵌入式系统一般使用C语言进行开发,由于C语言标准库没有封装链表,所以嵌入式系统一般自己设计和实现链表这种数据结构。单链表是链表中的一种,本文描述Open......
  • 算法--链表
       方法一:构造链表如果此类型的题出现在笔试中,如果内存要求不高,可以采用如下方法:可以先用一个vector将单链表的指针都存起来,然后再构造链表。此方法简单易懂,代码好......
  • leetcode 83. Remove Duplicates from Sorted List 删除排序链表中的重复元素(简单)
    一、题目大意给定一个已排序的链表的头head,删除所有重复的元素,使每个元素只出现一次。返回已排序的链表。示例1:输入:head=[1,1,2]输出:[1,2]示例2:输入:h......
  • 设计链表
    设计链表设计链表的实现。您可以选择使用单链表或双链表。单链表中的节点应该具有两个属性:val和next。val是当前节点的值,next是指向下一个节点的指针/引用。如果要使......
  • [数据结构10分钟入门] 面向初学者从零实现(基于C语言)-- 单链表
    ​一、链表是什么    链表是一种通过指针串联在一起的线性结构,在内存中是分散存储的(数组在内存中连续分布),链表由一系列节点组成,每个节点都由数据域和指针域组成。主......
  • 线性表(二)单链表
    单链表LinkList.htypedefintElemType;typedefstruct{ElemTypedata;//数据结点structLNode*next;//指向下一个结点的指针}LNode;typedefLNode*Lin......