leetcode_链表 21.合并两个有序链表

server/2025/1/31 18:03:46/

21.合并两个有序链表

  • 将两个升序链表合并为一个新的升序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
  • 思路:
    1. 定义一个哑节点(dummy node),哑节点是一个初始的虚拟节点,它不存储有效值,只是方便操作,定义一个指针 current 指向哑节点,用于构建新链表
    2. 遍历两个链表,使用两个指针 p1 和 p2 分别指向 list1 和 list2 的头部,并比较 p1.val 和 p2.val,将较小值的节点连接到 current.next。
    3. 处理剩余部分,当一个链表遍历完后,将另一个链表的剩余部分直接连接到 current.next。
    4. 返回结果,最终返回哑节点的下一个节点 dummy.next,即为合并后的链表头。
# Definition for singly-linked list.
# class ListNode(object):
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution(object):def mergeTwoLists(self, list1, list2):# 定义哑节点和当前指针dummy = ListNode(-1)  # 哑节点,初始值无意义current = dummy# 遍历两个链表while list1 and list2:if list1.val <= list2.val:  # 比较两个链表当前节点的值current.next = list1  # 将list1当前节点连接到结果链表list1 = list1.next  # 移动list1指针else:current.next = list2  # 将list2当前节点连接到结果链表list2 = list2.next  # 移动list2指针current = current.next  # 移动结果链表指针# 处理剩余部分if list1:  # 如果list1还有节点current.next = list1if list2:  # 如果list2还有节点current.next = list2# 返回合并后的链表return dummy.next""":type list1: Optional[ListNode]:type list2: Optional[ListNode]:rtype: Optional[ListNode]"""
  • 时间复杂度:O(m+n)
    • 每次操作一个节点,总共需要遍历两个链表的所有节点,即时间复杂度为 O(n + m),其中 n 和 m 是两个链表的长度。
  • 空间复杂度:O(1)

http://www.ppmy.cn/server/163851.html

相关文章

【计算机网络】设备更换地区后无法访问云服务器问题

文章目录 1. **服务器的公网 IP 是否变了**2. **服务器的防火墙或安全组设置**3. **本地运营商或 NAT 限制**4. **ISP 限制或端口封锁**5. **服务器监听地址检查** 1. 服务器的公网 IP 是否变了 在服务器上运行以下命令&#xff0c;检查当前的公网 IP&#xff1a;curl ifconfi…

【游戏设计原理】93 - 节奏

与“序-破-急”类似的节奏概念广泛存在于全球不同文化和创意领域中。以下是一些常见的节奏框架和理论&#xff0c;它们与“序-破-急”在本质上有相似之处&#xff0c;但体现出不同的风格和应用&#xff1a; 1. 三幕式结构&#xff08;Three-Act Structure&#xff09; 来源&a…

179最大数(贪心算法)分析+源码+证明

文章目录 题目题目分析算法原理 源码证明 思考 题目 给定一组非负整数 nums&#xff0c;重新排列每个数的顺序&#xff08;每个数不可拆分&#xff09;使之组成一个最大的整数。 注意&#xff1a;输出结果可能非常大&#xff0c;所以你需要返回一个字符串而不是整数。 题目分…

探索JavaScript前端开发:开启交互之门的神奇钥匙(二)

目录 引言 四、事件处理 4.1 事件类型 4.2 事件监听器 五、实战案例&#xff1a;打造简易待办事项列表 5.1 HTML 结构搭建 5.2 JavaScript 功能实现 六、进阶拓展&#xff1a;异步编程与 Ajax 6.1 异步编程概念 6.2 Ajax 原理与使用 七、前沿框架&#xff1a;Vue.js …

大数据治理实战:架构、方法与最佳实践

&#x1f4dd;个人主页&#x1f339;&#xff1a;一ge科研小菜鸡-CSDN博客 &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; 1. 引言 大数据治理是确保数据质量、合规性和安全性的重要手段&#xff0c;尤其在数据驱动决策和人工智能应用日益普及的背景下&…

1、云计算

云是一种基于互联网的计算技术和服务模式&#xff0c;它可以将计算资源、存储资源、软件资源等进行整合和虚拟化&#xff0c;以按需使用、可灵活扩展的方式提供给用户&#xff0c;就像把传统的本地计算资源和服务放到了一个庞大的 “云端”&#xff0c;用户可以通过网络随时随地…

RK3568 opencv播放视频

文章目录 一、opencv相关视频播放类1. cv::VideoCapture 类主要构造方法&#xff1a;主要方法&#xff1a; 2. 视频播放基本流程代码示例&#xff1a; 3. 获取和设置视频属性4. 结合 FFmpeg 使用5. OpenCV 视频播放的局限性6. 结合 Qt 实现更高级的视频播放总结 二、QT中的代码…

动态规划DP 最长上升子序列模型 总览

最长上升子序列模型 1. 最长上升子序列 1.1 怪盗基德的滑翔伞 1.1.1 登山 1.1.2 合唱队形 1.2 友好城市 1.3 最长上升子序列和 1.4 导弹拦截