news 2026/4/16 17:44:48

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【每天学习一点算法 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)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 9:01:53

10 个研究生课堂汇报 AI 工具推荐,提升效率神器

10 个研究生课堂汇报 AI 工具推荐&#xff0c;提升效率神器 论文写作的“三座大山”&#xff1a;时间、重复率与自我折磨 对于研究生来说&#xff0c;课堂汇报不仅是学术能力的体现&#xff0c;更是对研究深度和表达逻辑的综合考验。然而&#xff0c;面对繁重的课程任务、密集的…

作者头像 李华
网站建设 2026/4/16 9:01:20

终极串口调试指南:专业工程师的高效通信解决方案

终极串口调试指南&#xff1a;专业工程师的高效通信解决方案 【免费下载链接】串口助手SerialPortUtility使用说明 Serial Port Utility是一款功能强大的串口调试工具&#xff0c;以其小巧的体积和简便的操作深受用户喜爱。它支持自动刷新串口号&#xff0c;能够快速检测并连接…

作者头像 李华
网站建设 2026/4/16 9:08:24

http协议中各个网段含义

Informational&#xff08;信息性&#xff09;——“请稍等&#xff0c;我还没完呢” 只有协议交互用&#xff0c;浏览器层面基本看不到。 1. 100 Continue 场景&#xff1a;客户端准备在 POST/PUT 里扔几百 KB 甚至几十 MB 的表单或文件&#xff0c;怕一发过去就被拒&#…

作者头像 李华