news 2026/4/20 6:01:35

【每日算法】24. 两两交换链表中的节点

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【每日算法】24. 两两交换链表中的节点

对前端开发者而言,学习算法绝非为了“炫技”。它是你从“页面构建者”迈向“复杂系统设计者”的关键阶梯。它将你的编码能力从“实现功能”提升到“设计优雅、高效解决方案”的层面。从现在开始,每天投入一小段时间,结合前端场景去理解和练习,你将会感受到自身技术视野和问题解决能力的质的飞跃。------ 算法:资深前端开发者的进阶引擎

LeetCode 24. 两两交换链表中的节点

1. 题目描述

给定一个链表,两两交换其中相邻的节点,并返回交换后的链表。你必须在不修改节点内部值的情况下完成本题(即只能进行节点交换)。

示例1:

输入:head = [1,2,3,4] 输出:[2,1,4,3]

示例2:

输入:head = [] 输出:[]

示例3:

输入:head = [1] 输出:[1]

2. 问题分析

这是一个经典的链表操作问题,在前端开发中,类似的操作在处理DOM元素重新排列、数据流管道转换等场景都会遇到。链表节点的交换需要考虑以下几个关键点:

  1. 相邻节点间的指针修改
  2. 交换后与前后节点的连接
  3. 边界条件处理(空链表、单节点链表)
  4. 操作顺序避免链表断裂

3. 解题思路

3.1 迭代法(最优解)

使用虚拟头节点(dummy node)简化边界处理,通过三个指针(pre, node1, node2)完成相邻节点交换。

时间复杂度:O(n)
空间复杂度:O(1)

3.2 递归法

利用递归的栈空间,将问题分解为:交换前两个节点,然后递归处理剩余链表。

时间复杂度:O(n)
空间复杂度:O(n)(递归栈空间)

4. 各思路代码实现

4.1 迭代法实现

/** * Definition for singly-linked list. * function ListNode(val, next) { * this.val = (val===undefined ? 0 : val) * this.next = (next===undefined ? null : next) * } */constswapPairs=function(head){// 创建虚拟头节点,简化边界处理constdummy=newListNode(0,head);letpre=dummy;while(pre.next&&pre.next.next){// 定位要交换的两个节点constnode1=pre.next;constnode2=pre.next.next;// 执行交换操作// 1. 将pre指向node2pre.next=node2;// 2. 将node1指向node2的下一个节点node1.next=node2.next;// 3. 将node2指向node1node2.next=node1;// 移动pre指针,准备下一轮交换pre=node1;}returndummy.next;};

4.2 递归法实现

constswapPairs=function(head){// 递归终止条件:没有节点或只有一个节点if(!head||!head.next){returnhead;}// 要交换的两个节点constnode1=head;constnode2=head.next;// node1指向后续递归结果node1.next=swapPairs(node2.next);// node2指向node1完成交换node2.next=node1;// 返回新的头节点returnnode2;};

5. 各实现思路的复杂度、优缺点对比

方法时间复杂度空间复杂度优点缺点适用场景
迭代法O(n)O(1)空间效率高,适合处理大链表;操作直观需要处理多个指针,边界条件需小心生产环境推荐,内存敏感场景
递归法O(n)O(n)代码简洁,逻辑清晰;符合分治思想递归深度受链表长度限制;栈空间开销大链表长度有限;学习理解递归思想

6. 总结

6.1 算法思想应用

链表节点交换问题体现了以下重要思想:

  1. 虚拟头节点技巧:简化边界处理,避免对头节点的特殊判断
  2. 多指针操作:在链表操作中,合理使用多个指针可以清晰表达操作意图
  3. 递归与分治:将大问题分解为相同的小问题解决

6.2 前端实际应用场景

  1. DOM元素重排:在实现拖拽排序、列表项交换时,类似的指针操作思想可以帮助优化DOM操作
  2. 数据流处理:在处理管道化的数据转换时,链表操作思想有助于设计高效的数据处理链
  3. 状态管理:在复杂状态流转场景中,节点交换思想可用于状态迁移管理
  4. 虚拟DOM Diff:React等框架的diff算法中,包含类似节点位置交换的优化策略
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 7:38:50

抖音小程序开发(uniapp)

1、下载抖音开发者工具 抖音开发者工具下载地址: https://developer.open-douyin.com/docs/resource/zh-CN/mini-app/develop/dev-tools/developer-instrument/download/developer-instrument-update-and-download 2、启动项目 选择如图运行到抖音开发者工具 如…

作者头像 李华
网站建设 2026/4/19 15:00:22

错过再等一年!Dify工作流重试机制内部资料曝光(附源码级解析)

第一章:错过再等一年!Dify工作流重试机制全貌揭秘在构建高可用的AI应用时,网络波动、模型超时或临时性服务异常难以避免。Dify 工作流引擎内置了智能重试机制,确保关键任务在短暂失败后仍能自动恢复执行,极大提升系统鲁…

作者头像 李华
网站建设 2026/4/17 8:44:21

js未授权简介

一、什么是未授权? 首先理解什么是未授权漏洞 未授权字面上理解是未获得授权,对于正常的业务来说,有些功能点需要经过登录之后才能进行,那么如果我们通过一些绕过,无需登录也可以完成此类操作,那么便是未授权访问漏洞了。 二、常见的未授权访问漏洞 常见的未授权漏洞一…

作者头像 李华
网站建设 2026/4/16 18:29:26

方舟引擎如何打破性能枷锁,铸造“超级隐私模式”的实现之道

摘要: 在数字时代,用户隐私与应用性能似乎陷入了一场零和博弈。我们渴望极致的隐私保护,却又无法忍受由此带来的性能下降和体验割裂。本文将跳出传统浏览器“无痕模式”的局限,构想一种系统级的“超级隐私模式”,并深入…

作者头像 李华
网站建设 2026/4/17 12:24:41

为什么你的Shiny应用越跑越慢?(多模态缓存缺失的代价)

第一章:为什么你的Shiny应用越跑越慢?当你最初部署 Shiny 应用时,响应迅速、交互流畅。但随着用户量增加或数据规模扩大,应用逐渐变得卡顿甚至无响应。性能下降通常并非单一原因所致,而是多个潜在瓶颈累积的结果。无效…

作者头像 李华
网站建设 2026/4/18 17:19:58

7、Linux 文件共享与查找全攻略

Linux 文件共享与查找全攻略 在 Linux 系统中,文件共享和查找是非常重要的操作,掌握这些操作可以帮助我们更好地管理和使用文件。下面将详细介绍 Linux 中文件共享和查找的相关知识和操作方法。 1. 文件共享 1.1 分组协作 在 Linux 里,组是为了实现文件共享和促进协作而…

作者头像 李华