C++力扣题目19--删除链表的倒数第N个结点
给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。
示例 1:

输入:head = [1,2,3,4,5], n = 2 输出:[1,2,3,5]
思路:双指针的经典应用,如果要删除倒数第n个节点,让fast移动n步,然后让fast和slow同时移动,直到fast指向链表末尾。删掉slow所指向的节点就可以了。下面有图


class Solution {
public:
ListNode* removeNthFromEnd(ListNode* head, int n) {
ListNode* virhead = new ListNode();
virhead->next = head;
ListNode* fast = virhead;
ListNode* slow = virhead;
while (n >= 0&&fast)//让fast先走n+1步,之后再和slow一起走,
{ //等fast走到最后结点,slow和它相差n+1,
// slow正好到了要删除的结点的前驱结点处
fast = fast->next;
n--;
}
while (fast)
{
fast = fast->next;
slow = slow->next;
}
ListNode* p = slow->next;//删除结点
slow->next = slow->next->next;
delete p;
return virhead->next;
}
};