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;
    }
};