zoukankan      html  css  js  c++  java
  • 【Leetcode 】21:合并两个有序链表(Python)

    题目:

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

    示例:

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

    解题思路:

    直接使用递归,也就是整体法进行编写,假设其中第一个链表的数字比另一个数小,则将后面的两个链表使用merge函数打乱重新排序然后得到最后的结果。代码如下:

    # 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, l1: ListNode, l2: ListNode) -> ListNode:
          #假设l1当中啥都没有,则返回l2,因为l2当中的node一定是升序排列的
    if l1==None: return l2 if l2==None: return l1 if l1.val<l2.val: l1.next=self.mergeTwoLists(l1.next,l2) return l1 else: l2.next=self.mergeTwoLists(l1,l2.next) return l2

    方法2

    这道题除了使用递归之外,还可以使用迭代的方法求解,使用迭代的方法求解也非常简单。这里可以采用merge sort(归并排序)当中进行merge(归并)的一个思想。 也就是说我们可以分别在两个链表的表头对链表的value进行比较,将较小的一个node放到新的,我们需要进行返回的链表当中。然后链表的指针向后移动一格,再进行新一轮的比较。如果两个链表的表头的大小是相同的话,则将其均放入到新的需要返回的链表当中。

    代码如下:

    # 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, l1: ListNode, l2: ListNode) -> ListNode:
            ret=ListNode(0)
            real_ret=ret
            while l1 or l2:
                if l1!=None and l2!=None:
                    one=l1.val
                    two=l2.val
                    if one<two:
                        ret.next=ListNode(one)
                        ret=ret.next
                        l1=l1.next
                    if two<one:
                        ret.next=ListNode(two)
                        ret=ret.next
                        l2=l2.next
                    if one==two:
                        ret.next=ListNode(two)
                        ret=ret.next
                        ret.next=ListNode(two)
                        ret=ret.next
                        l1=l1.next
                        l2=l2.next
                if l1!=None and l2==None:
                    ret.next=ListNode(l1.val)
                    ret=ret.next
                    l1=l1.next
                if l1==None and l2!=None:
                    ret.next=ListNode(l2.val)
                    ret=ret.next
                    l2=l2.next
            return real_ret.next
  • 相关阅读:
    linux 文件系统(inode和block)
    vue状态管理vuex从浅入深详细讲解
    小白都能看懂的vue中各种通信传值方式,附带详细代码
    CSS3移动端vw+rem不依赖JS实现响应式布局
    JavaScript原生封装ajax请求和Jquery中的ajax请求
    永久解决Sublime包管理package control 打开install package报错 There are no packages available for installation
    从GitLab上创建分支本地拉取项目和提交项目详解
    前端路由的两种实现方式,内附详细代码
    几个例子理解浅拷贝和深拷贝
    讲解JavaScript中对闭包的理解
  • 原文地址:https://www.cnblogs.com/geeksongs/p/13573976.html
Copyright © 2011-2022 走看看