📑 题目:19. 删除链表的倒数第 N 个结点
题目大意
删除链表中倒数第 n 个结点。
解题思路
这道题比较简单,先循环一次拿到链表的总长度,然后循环到要删除的结点的前一个结点开始删除操作。需要注意的一个特例是,有可能要删除头结点,要单独处理。
这道题有一种特别简单的解法。设置 2 个指针,一个指针距离前一个指针 n 个距离。同时移动 2 个指针,2 个指针都移动相同的距离。当一个指针移动到了终点,那么前一个指针就是倒数第 n 个节点了。
代码
package leetcodeimport (""github.com/halfrost/LeetCode-Go/structures"")// ListNode definetype ListNode = structures.ListNode/*** Definition for singly-linked list.* type ListNode struct {* Val int* Next *ListNode* }*/// 解法一func removeNthFromEnd(head *ListNode, n int) *ListNode {dummyHead := &ListNode{Next: head}preSlow, slow, fast := dummyHead, head, headfor fast != nil {if n <= 0 {preSlow = slowslow = slow.Next}n--fast = fast.Next}preSlow.Next = slow.Nextreturn dummyHead.Next}// 解法二func removeNthFromEnd1(head *ListNode, n int) *ListNode {if head == nil {return nil}if n <= 0 {return head}current := headlen := 0for current != nil {len++current = current.Next}if n > len {return head}if n == len {current := headhead = head.Nextcurrent.Next = nilreturn head}current = headi := 0for current != nil {if i == len-n-1 {deleteNode := current.Nextcurrent.Next = current.Next.NextdeleteNode.Next = nilbreak}i++current = current.Next}return head}
