当前位置:首页 > 编程笔记 > 正文
已解决

21. 合并两个有序链表、Leetcode的Python实现

来自网友在路上 161861提问 提问时间:2023-10-31 00:55:56阅读次数: 61

最佳答案 问答题库618位专家为你答疑解惑

  博客主页:🏆看看是李XX还是李歘歘 🏆

🌺每天不定期分享一些包括但不限于计算机基础、算法、后端开发相关的知识点,以及职场小菜鸡的生活。🌺

💗点关注不迷路,总有一些📖知识点📖是你想要的💗

⛽️今天的内容是     Leetcode  203. 移除链表元素      ⛽️💻💻💻

21. 合并两个有序链表

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

示例 1:

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

示例 2:

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

示例 3:

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

提示:

    两个链表的节点数目范围是 [0, 50]
    -100 <= Node.val <= 100
    l1 和 l2 均按 非递减顺序 排列

递归:

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:def mergeTwoLists(self, list1: Optional[ListNode], list2: Optional[ListNode]) -> Optional[ListNode]:if list1 is None:return list2if list2 is None:return list1if list1.val<list2.val:list1.next = self.mergeTwoLists(list1.next,list2)return list1else:list2.next = self.mergeTwoLists(list1,list2.next)return list2

迭代:

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, val=0, next=None):
#         self.val = val
#         self.next = next
class Solution:def mergeTwoLists(self, list1: Optional[ListNode], list2: Optional[ListNode]) -> Optional[ListNode]:result = ListNodetmp = resultwhile list1 is not None and list2 is not None :if list1.val<list2.val :tmp.next,list1 = list1,list1.nextelse :tmp.next,list2 = list2,list2.nexttmp = tmp.nexttmp.next = list1 if list1 else list2return result.next

查看全文

99%的人还看了

猜你感兴趣

版权申明

本文"21. 合并两个有序链表、Leetcode的Python实现":http://eshow365.cn/6-28182-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!