[LeetCode] Remove Nth Node From End of List 解题报告
Given a linked list, remove the nth node from the end of list and return its head.
For example,
Given linked list: 1->2->3->4->5, and n = 2.
After removing the second node from the end, the linked list becomes 1->2->3->5.
Note:
Given n will always be valid.
Try to do this in one pass.
» Solve this problemGiven n will always be valid.
Try to do this in one pass.
[解题思路]
经典题。双指针,一个指针先走n步,然后两个同步走,直到第一个走到终点,第二个指针就是需要删除的节点。唯一要注意的就是头节点的处理,比如,
1->2->NULL, n =2; 这时,要删除的就是头节点。
[Code]
1: ListNode *removeNthFromEnd(ListNode *head, int n) {
2: // Start typing your C/C++ solution below
3: // DO NOT write int main() function
4: assert(head);
5: ListNode* pre, *cur;
6: pre = head;cur = head;
7: int step = 0;
8: while(step< n && cur!=NULL)
9: {
10: cur = cur->next;
11: step++;
12: }
13: if(step ==n && cur == NULL)
14: {
15: head = head->next;
16: delete pre;
17: return head;
18: }
19: while(cur->next!=NULL)
20: {
21: pre = pre->next;
22: cur = cur->next;
23: }
24: ListNode* temp = pre->next;
25: pre->next = temp->next;
26: delete temp;
27: return head;
28: }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,携手博客园推出1Panel与Halo联合会员
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微服务架构学习与思考:微服务拆分的原则
· 记一次 .NET某云HIS系统 CPU爆高分析
· 如果单表数据量大,只能考虑分库分表吗?
· 一文彻底搞懂 MCP:AI 大模型的标准化工具箱
· 电商平台中订单未支付过期如何实现自动关单?
· 精选 4 款免费且实用的数据库管理工具,程序员必备!
· Cursor:一个让程序员“失业”的AI代码搭子
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(6)
· 重生之我是操作系统(七)----内存管理(上)
· .NET 阻止Windows关机以及阻止失败的一些原因