代码随想录第四天 2023.7.15
题目链接:
19. 删除链表的倒数第 N 个结点 - 力扣(Leetcode)https://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次来进行