LeetCode21.2つの整列チェーンテーブルpython 3をマージ
1037 ワード
2つの順序付きチェーンテーブルを新しい順序付きチェーンテーブルに結合して返します.新しいチェーンテーブルは、指定された2つのチェーンテーブルのすべてのノードを接合することによって構成されます.
例:
入力:1->2->4、1->3->4出力:1->1->2->3->4->4
考え方:初心者の第一印象はチェーンテーブルをつなげて並べ替えることに違いありません.totally OK、大丈夫ですが、時間の複雑さは間違いなく高いです.そこで第2のアイデアは,空間的複雑さを増大させ,L 1,L 2を順番に継続する新しいチェーンテーブルを作成することではない.次のようになります.
例:
入力:1->2->4、1->3->4出力:1->1->2->3->4->4
考え方:初心者の第一印象はチェーンテーブルをつなげて並べ替えることに違いありません.totally OK、大丈夫ですが、時間の複雑さは間違いなく高いです.そこで第2のアイデアは,空間的複雑さを増大させ,L 1,L 2を順番に継続する新しいチェーンテーブルを作成することではない.次のようになります.
# Definition for singly-linked list.
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def mergeTwoLists(self, l1, l2):
head = ListNode(0)
New_list = head
while l1 != None and l2 != None:
if l1.val > l2.val:
head.next = l2
l2 = l2.next
else:
head.next = l1
l1 = l1.next
head = head.next
if l2 != None:
head.next = l2
elif l1 != None:
head.next = l1
return New_list.next
#New_list , 0, return