题目描述
给你一个链表,删除链表的倒数第 n
个结点,并且返回链表的头结点
题解
本题依旧涉及到可能对头结点的操作,故继续使用虚拟头节点
本题采用双指针法,fast先走n+1步,之后和slow每轮循环各自向前走一步,直至fast到末尾,走n+1步的目的是让slow停在待删除的节点的上一个结点,便于操作
/**
* 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=fast;
for(int i=0;i<n;i++)
fast=fast->next;
while(fast->next!=nullptr)
{
slow=slow->next;
fast=fast->next;
}
ListNode* temp=slow->next;
slow->next=slow->next->next;
delete temp;
return dummyhead->next;
}
};
注意事项
1.虚拟头节点往往使用在需要对链表头结点进行操作的时候