C++开发:迭代与递归两种方式实现单链表倒置及内存消耗分析
在C++中,可以使用迭代或递归的方式来反转单链表。以下是两种方法的示例: 方法一:迭代 ```cpp struct ListNode { int val; ListNode *next; ListNode(int x) : val(x), next(NULL) {} }; ListNode* reverseList(ListNode* head) { ListNode *prev = NULL, *curr = head, *next = NULL; while (curr != NULL) { next = curr->next; curr->next = prev; prev = curr; curr = next; } return prev; } ``` 方法二:递归 ```cpp ListNode* reverseList(ListNode* head) { if (head == NULL || head->next == NULL) { return head; } ListNode* newHead = reverseList(head->next); head->next->next = head; head->next = NULL; return newHead; } ``` 这两种方法都可以有效地反转单链表,但递归的方法可能在处理大型链表时会消耗更多的内存。 ######[AI写代码神器 | 224点数解答 | 2023-11-09 00:41:04]
相关提问
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)479
- C#工程师必知:数组、链表、哈希、队列、栈数据结构优缺点大揭秘! (百度文心 | 561点数解答 | 2023-11-09 17:56:30)290
- Java 实现仿 Windows 资源管理器:文件管理器功能全解析与代码示例(字节豆包 | 623点数解答 | 2025-01-01 14:59:04)290
- Python 实现:统计玩具工厂红蓝色积木数量(字节豆包 | 169点数解答 | 2025-11-11 21:29:06)150
- Python 实现:统计红蓝色积木数量的详细攻略(字节豆包 | 299点数解答 | 2025-11-11 21:30:03)140
- Python 实现:带边界处理与验证的任意基数数字转换递归程序(字节豆包 | 198点数解答 | 2024-11-21 14:20:25)472
- Python 递归函数实现:将数字转换为指定基数的输出(百度文心 | 499点数解答 | 2024-11-22 09:58:55)370
- 编程模拟:偶数张牌经 k 次洗牌后第 p 张牌编号求解(DeepSeek | 126点数解答 | 2026-01-05 12:15:30)58
- 螺旋矩阵:根据输入行列号精准求出对应位置数字的算法揭秘(DeepSeek | 740点数解答 | 2026-01-05 12:16:41)79
- 解决Forge 47.4.10下载及安装失败问题的方法(字节豆包 | 575点数解答 | 2026-05-05 10:57:28)62
- 解决 Forge 47.4.10 下载安装失败及 Java 虚拟机启动类路径问题(字节豆包 | 452点数解答 | 2026-05-05 10:59:17)46
- Java 实现:轻松生成 5 位数字、大小写字母混合验证码( | 266点数解答 | 2024-03-06 17:39:10)365