Loading

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

   
}
posted @ 2022-09-05 15:35  suehoo  阅读(23)  评论(0)    收藏  举报