news 2026/4/28 8:09:11

两两交换链表中的节点

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
两两交换链表中的节点

递归解法详解

题目要求两两交换链表中的相邻节点,且不能修改节点的值,只能交换节点本身。递归方法通过分解问题为子问题来实现。

递归思路将链表的前两个节点视为node1node2,交换这两个节点后,node1的下一个节点应指向剩余链表交换后的头节点。递归终止条件是链表为空或只有一个节点。

代码实现(C++)

class Solution { public: ListNode* swapPairs(ListNode* head) { if (head == nullptr || head->next == nullptr) { return head; } ListNode* newHead = head->next; head->next = swapPairs(newHead->next); newHead->next = head; return newHead; } };

执行流程示例输入链表:1 → 2 → 3 → 4

  1. 第一次递归:head=1newHead=2,递归处理3
  2. 第二次递归:head=3newHead=4,递归处理nullptr,返回nullptr
  3. 连接子链表结果:3->next=nullptr4->next=3,返回4
  4. 最终连接:1->next=42->next=1,返回2,结果为2→1→4→3

复杂度分析

  • 时间复杂度:$O(n)$,每个节点处理一次。
  • 空间复杂度:$O(n)$,递归栈深度为$n/2$。

迭代解法补充

迭代思路使用指针遍历链表,每次交换相邻两个节点,并更新指针位置。

代码实现(C++)

class Solution { public: ListNode* swapPairs(ListNode* head) { ListNode dummy(0); dummy.next = head; ListNode* prev = &dummy; while (prev->next && prev->next->next) { ListNode* first = prev->next; ListNode* second = first->next; prev->next = second; first->next = second->next; second->next = first; prev = first; } return dummy.next; } };

执行流程

  1. 初始化虚拟头节点dummyprev指向dummy
  2. 循环中交换firstsecond节点,更新prev->nextfirst->next
  3. 移动prevfirst,继续处理下一对节点。

复杂度分析

  • 时间复杂度:$O(n)$,遍历链表一次。
  • 空间复杂度:$O(1)$,仅使用常数空间。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/28 0:11:13

飞书文档批量导出神器:三步搞定知识库迁移

飞书文档批量导出神器:三步搞定知识库迁移 【免费下载链接】feishu-doc-export 项目地址: https://gitcode.com/gh_mirrors/fe/feishu-doc-export 还在为飞书文档迁移而烦恼吗?面对成百上千的文档,手动下载不仅耗时耗力,还…

作者头像 李华
网站建设 2026/4/17 7:37:47

微信防撤回神器:WeChatIntercept让macOS用户永久留住重要信息

微信防撤回神器:WeChatIntercept让macOS用户永久留住重要信息 【免费下载链接】WeChatIntercept 微信防撤回插件,一键安装,仅MAC可用,支持v3.7.0微信 项目地址: https://gitcode.com/gh_mirrors/we/WeChatIntercept 在商务…

作者头像 李华
网站建设 2026/4/25 10:02:52

NVIDIA Profile Inspector深度解析:解锁显卡驱动的隐藏潜能

NVIDIA Profile Inspector深度解析:解锁显卡驱动的隐藏潜能 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector NVIDIA Profile Inspector作为一款专业级显卡配置工具,突破了官方驱动…

作者头像 李华
网站建设 2026/4/19 14:55:10

终极NVIDIA Profile Inspector显卡性能优化完整指南

终极NVIDIA Profile Inspector显卡性能优化完整指南 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector NVIDIA Profile Inspector是一款专业的显卡优化工具,能够深度调整NVIDIA显卡驱动中的隐藏…

作者头像 李华
网站建设 2026/4/27 1:09:30

原神自动化助手完全使用手册:从入门到精通的全流程指南

原神自动化助手完全使用手册:从入门到精通的全流程指南 【免费下载链接】better-genshin-impact 🍨BetterGI 更好的原神 - 自动拾取 | 自动剧情 | 全自动钓鱼(AI) | 全自动七圣召唤 | 自动伐木 | 自动派遣 | 一键强化 - UI Automation Testing Tools Fo…

作者头像 李华