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

代码随想录第四天 2023.7.15

题目链接:

19. 删除链表的倒数第 N 个结点 - 力扣(Leetcode)icon-default.png?t=N6B9https://leetcode.cn/problems/remove-nth-node-from-end-of-list/

代码如下:

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* removeNthFromEnd(ListNode* head, int n) {
            ListNode* dummyHead=new ListNode(0);
            dummyHead->next=head;
            ListNode* fast=dummyHead;
            ListNode* slow=dummyHead;
            while(n--&&fast->next!=nullptr){
                fast=fast->next;
            }
            fast=fast->next;
            while(fast!=nullptr){
                fast=fast->next;
                slow=slow->next;
            }
            slow->next = slow->next->next;
   
            return dummyHead->next;
    }
};

注意:需要重点掌握并熟悉删除链表倒数第n个节点这一类型题的操作步骤和思路

1.删除链表中的倒数或正数的第n个节点,需要一个指针指向其前一个元素,这样方便删除操作

2.首先设立一个虚拟头节点指向实际的头节点,这样的处理方便删除实际的头节点(若题目要求删除头结点)

3.定义一个快指针fast和一个慢指针slow两个指针初始值均指向虚拟头节点

4.fast快指针先移动n+1步之后,fast和slow同时移动,直到fast指向NULL,slow此时指向删除节点的上一个节点,这一点需要重点理解掌握

5.错误:第一次写代码时,因为fast要移动n+1步,所以直接把代码写上了如下的形式导致代码报错

n=n+1;
            while(n--&&fast->next!=nullptr){
                fast=fast->next;
            }

        检查后错误原因如下:当列表中只有一个元素且n=1即删除倒数第一个也是正数第一个元素时,n在递增后值为2,while循环执行两次,在第二次执行时会发生空指针报错,所以fast指针的n+1步移动要分成n次和1次来进行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值