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

Leetcode力扣解题记录--第21题(合并链表)

题目链接:21. 合并两个有序链表 - 力扣(LeetCode)

题目描述

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

示例 1:

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

示例 2:

输入:l1 = [], l2 = []
输出:[]

示例 3:

输入:l1 = [], l2 = [0]
输出:[0]

题目作答

  1. 双指针遍历:使用两个指针分别遍历两个链表,比较当前节点值的大小,选择较小值的节点加入新链表。

  2. 递归或迭代

    • 递归:通过递归调用合并剩余部分,代码简洁但可能导致栈溢出。

    • 迭代:使用迭代模拟递归过程,通过虚拟头节点简化边界处理。

  3. 边界处理:若任一链表为空,直接返回另一链表;合并完成后,将剩余链表直接连接到结果末尾。

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode() : val(0), next(nullptr) {}*     ListNode(int x) : val(x), next(nullptr) {}*     ListNode(int x, ListNode *next) : val(x), next(next) {}* };*/
class Solution {
public:ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {// 边界条件:若任一链表为空,返回另一链表if (!list1) return list2;if (!list2) return list1;// 递归合并if (list1->val <= list2->val) {list1->next = mergeTwoLists(list1->next, list2);return list1;} else {list2->next = mergeTwoLists(list1, list2->next);return list2;}}
};

http://www.lryc.cn/news/599236.html

相关文章:

  • CentOS8 使用 Docker 搭建 Jellyfin 家庭影音服务器
  • Vim 编辑器全模式操作指南
  • 短剧小程序系统开发:构建影视娱乐生态新格局
  • Java常用命令、JVM常用命令
  • Android Room 持久化库:简化数据库操作
  • pycharm安装教程-PyCharm2023安装详细步骤【MAC版】【安装包自取】
  • PyCharm高效开发全攻略
  • IP证书:构建数字世界知识产权安全防线的基石
  • Java零基础入门学习知识点2-JDK安装配置+Maven
  • Qwen3-235B-A22B-Thinking-2507 - 开源思维推理模型的新标杆
  • 深入解析Hadoop YARN如何避免资源死锁:机制与实战
  • Androidstudio 上传当前module 或本地jar包到maven服务器。
  • C++调用GnuPlot一维绘图
  • 微信小程序中英文切换miniprogram-i18n-plus
  • 三、Spark 运行环境部署:全面掌握四种核心模式
  • day33:零基础学嵌入式之网络——HTTP服务端
  • GaussDB 逻辑备份实操
  • 《剑指offer》-数据结构篇-链表
  • Java 大视界 -- Java 大数据机器学习模型在金融衍生品市场波动特征挖掘与交易策略创新中的应用(363)
  • MySQL存储引擎深度解析与实战指南
  • 电科金仓新一代数据库一体机:国产化方案替换优质选择
  • Java研学-RabbitMQ(三)
  • LeetCode 391:完美矩形
  • SQL164 2021年11月每天新用户的次日留存率
  • 虚拟地址-物理地址
  • 关于“PromptPilot”
  • jwt 验证方法 (ASP.NET Core)
  • Uniapp编写微信小程序,绘制动态圆环进度条
  • Linux——线程(下)
  • uniapp小程序上传图片并压缩