19. 删除链表的倒数第 N 个结点
这题核心也就在于怎么找到倒数第k个点,其他也没啥了,建议在草稿纸上手动演算一下,结果就出来了
/**
* 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) {
auto dummy = new ListNode(-1);
dummy -> next = head;
//先求一下列表长度
int len = 0;
for(auto p = dummy;p;p = p->next) len++;
//删除倒数第n个点,我们就需要找到倒数第n+1个点 从dummy开始走len-n次正好走到倒数第n+1个点
auto p = dummy;
for(int i = 0;i < len - n - 1;i ++) p = p->next;
p->next = p->next->next;
return dummy->next;
}
};