zoukankan      html  css  js  c++  java
  • python刷LeetCode:21. 合并两个有序链表

    难度等级:简单

    题目描述:

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

    示例:

    输入:1->2->4, 1->3->4
    输出:1->1->2->3->4->4

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/merge-two-sorted-lists
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解题思路:

    1、此题主要考察对链表的操作

    2、解法有多种,此处采用递归

    3、不断比较大小,更新链表的下一节点

    解题代码:

    # Definition for singly-linked list.
    # class ListNode:
    #     def __init__(self, x):
    #         self.val = x
    #         self.next = None
    
    class Solution:
        def mergeTwoLists(self, l1: ListNode, l2: ListNode) -> ListNode:
            if not l1: return l2
            if not l2: return l1
            if l1.val < l2.val:  # 若当前l1数值小于l2,更新l1的下一节点,返回l1当前值
                l1.next = self.mergeTwoLists(l1.next,l2)  # 先将原l1.next传入进行递归比较,得到的值用来更新l1.next
                return l1
            else:  # 若当前l1数值大于等于l2,更新l2的下一节点,返回l2当前值
                l2.next = self.mergeTwoLists(l1,l2.next)  # 先将原l2.next传入进行递归比较,得到的值用来更新l2.next
                return l2
  • 相关阅读:
    k8s资源需求和限制, 以及pod驱逐策略
    python转义引起的错误
    nginx location 匹配目录
    kubelet 证书自动续期
    docker常见退出码
    (转)firefox火狐浏览器语言设置
    去掉表的identity属性
    SQL Server内存方面知识收集
    SQL Server 中not in和not exists
    Data Compression(1)
  • 原文地址:https://www.cnblogs.com/jaysonteng/p/12365331.html
Copyright © 2011-2022 走看看