day4 移出倒数第n个节点

ListNode* removeNthFromEnd(ListNode* head, int n) {

ListNode* dummyHead = new ListNode(0);

dummyHead->next = head;

ListNode* slow = dummyHead;

ListNode* fast = dummyHead;

while(n-- && fast != NULL) {

fast = fast->next;

}

fast = fast->next; // fast再提前走一步,因为需要让slow指向删除节点的上一个节点

while (fast != NULL) {

fast = fast->next;

slow = slow->next;

}

slow->next = slow->next->next;

// ListNode *tmp = slow->next; C++释放内存的逻辑

// slow->next = tmp->next;

// delete tmp;

return dummyHead->next;

}

相关推荐
leiming61 天前
C++ vector容器
开发语言·c++·算法
Xの哲學1 天前
Linux流量控制: 内核队列的深度剖析
linux·服务器·算法·架构·边缘计算
yaoh.wang1 天前
力扣(LeetCode) 88: 合并两个有序数组 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·双指针
LYFlied1 天前
【每日算法】 LeetCode 56. 合并区间
前端·算法·leetcode·面试·职场和发展
艾醒1 天前
大模型原理剖析——多头潜在注意力 (MLA) 详解
算法
艾醒1 天前
大模型原理剖析——DeepSeek-V3深度解析:671B参数MoE大模型的技术突破与实践
算法
jifengzhiling1 天前
零极点对消:原理、作用与风险
人工智能·算法
鲨莎分不晴1 天前
【前沿技术】Offline RL 全解:当强化学习失去“试错”的权利
人工智能·算法·机器学习
XFF不秃头1 天前
力扣刷题笔记-全排列
c++·笔记·算法·leetcode