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

删除链表的倒数第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

   
}

作者:suehoo

出处:https://www.cnblogs.com/suehoo/p/16658378.html

版权:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议进行许可。

posted @   suehoo  阅读(17)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示
more_horiz
keyboard_arrow_up dark_mode palette
选择主题
menu