当前位置: 首页 > news >正文

【每天学习一点算法 2025/12/11】合并两个有序链表

每天学习一点算法 2025/12/11

题目:合并两个有序链表

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

  1. 递归方法看过我反转链表的应该都知道递归链表的要点。

    因为是升序的链表,所以我们每次只选当前最小的节点,剩下的部分交给递归处理

    • 终止条件:其中一个链表遍历完成

      如果list1为空(遍历完了),说明剩下的部分直接用list2就行

      如果list2为空(遍历完了),说明剩下的部分直接用list1就行

    • 递:每次选择较小的节点,向下递归调用,这样每层递归节点的值都是大于等于上一层的

    • 归:递归触底,开始逐个拼接节点

    functionmergeTwoLists(list1:ListNode|null,list2:ListNode|null):ListNode|null{// 终止条件:其中一个链表遍历完成if(!list1)returnlist2if(!list2)returnlist1// 每次选择较小的节点,将更大的节点和自己的下一节点交给递归处理if(list1.val<list2.val){list1.next=mergeTwoLists(list1.next,list2)// 返回当前递归层选择的节点returnlist1}else{list2.next=mergeTwoLists(list1,list2.next)// 返回当前递归层选择的节点returnlist2}};
  2. 还有一种方法就是遍历链表,迭代出合并的结果。

    functionmergeTwoLists1(list1:ListNode|null,list2:ListNode|null):ListNode|null{// 创建一个节点用于迭代开头constprehead=newListNode(-1);letprev=prehead// 遍历链表直到其中一个链表结束while(list1!=null&&list2!=null){// 比较节点值迭代结果if(list1.val<=list2.val){prev.next=list1 list1=list1.next}else{prev.next=list2 list2=list2.next}prev=prev.next}// 合并剩余的部分prev.next=list1===null?list2:list1// 返回链表头returnprehead.next}

题目来源:力扣(LeetCode)

http://www.jsqmd.com/news/73382/

相关文章:

  • 探索双馈风力发电系统的双PWM变换器控制
  • [powershell 入门]第9天:PowerShell 安全、代码签名与企业部署 作业及深度解析
  • 【Linux 系统编程核心】进程的本质、管理与核心操作
  • 2025 最新货代 / 货运代理服务商 TOP5 评测!深度覆盖欧美加专线,全链路方案 + 全球网络权威榜单发布,赋能跨境电商与传统外贸高效出海 - 全局中转站
  • Selenium实战指南:用浏览器驱动轻松实现网络爬虫
  • 无监督学习的现代应用:聚类与异常检测在真实业务场景中的落地
  • 2025 最新货代方案服务商 / 厂家 TOP5 评测!深度覆盖欧美加专线,全链路协同 + 跨境直达权威榜单发布,赋能电商全球化布局新生态 - 全局中转站
  • NVIDIA Profile Inspector终极指南:免费解锁显卡隐藏性能
  • 基于Java Spring Boot的相机租赁系统的设计与实现-毕业设计源码50424
  • 12.11 - 最长回文子串 main函数是如何开始的
  • Python学习日记:探索列表的奥秘与编程乐趣
  • 基础数据结构:栈、队列、链表
  • Docker + 多模态Agent = 王炸组合?5个真实生产环境编排案例深度剖析
  • Windows上解决test.c LINK : fatal error LNK1181: 无法打开输入文件“aio.lib” 无法打开输入文件“cufile.lib”
  • 第十一章篇 实现拦截器
  • 揭秘MCP PL-600多模态Agent设计:如何实现跨模态协同与自主决策
  • 从零构建智能Agent编排系统,掌握Docker Swarm与K8s协同秘技
  • Docker Buildx构建缓慢?你必须知道的7个Agent镜像优化实践
  • Linux新手必学:tail命令图解指南
  • 8 个自考论文降重工具,AI 免费网站推荐
  • 如何为你的Python项目构建pyproject.toml文件
  • 新手鱼竿推荐:新手买钓鱼竿怎么选?2025年鱼竿新手入门推荐 - 品牌2026
  • C++ ⼀级 2023 年06 ⽉
  • NPI(New Product Introduction)工程师职责介绍
  • 卡内基跨学科团队利用随机森林模型,基于406份样本成功捕捉33亿年前生命遗迹
  • 【STM32】低功耗
  • 基于 ESP32 的对话机器人实现:整合 Coze 大模型、百度千帆 ASR 与 TTS
  • Spark 运行架构及相关概念
  • 基于SpringBoot的学生评奖评优管理系统-计算机毕业设计源码+LW文档分享
  • MySQL 主从同步与读写分离详解