本文最后更新于:2025年9月26日 凌晨
                  
                
              
            
            
              
                
                问题描述
将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 \
示例:
| 12
 
 | 输入:1->2->4, 1->3->4输出:1->1->2->3->4->4
 
 | 
解决方案
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 
 | 
 class Node(object):
 def __init__(self):
 self.val = None
 self.next = None
 
 def __str__(self):
 return str(self.val)
 
 
 def mergeTwoLists(l1, l2):
 
 if l1 is None:
 return l2
 if l2 is None:
 return l1
 
 if l2.val < l1.val:
 l1, l2 = l2, l1
 
 head = l1
 
 while l1.next is not None:
 
 if l2 is None:
 return head
 
 if l1.val <= l2.val <= l1.next.val:
 
 l1.next, l2.next, l2 = l2, l1.next, l2.next
 
 l1 = l1.next
 
 l1.next = l2
 return head
 
 | 
测试代码
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 
 | if __name__ == '__main__':
 three = Node()
 three.val = 3
 
 two = Node()
 two.val = 2
 two.next = three
 
 one = Node()
 one.val = 1
 one.next = two
 
 head = Node()
 head.val = 0
 head.next = one
 
 three1 = Node()
 three1.val = 3
 
 two1 = Node()
 two1.val = 2
 two1.next = three1
 
 one1 = Node()
 one1.val = 1
 one1.next = two1
 
 head1 = Node()
 head1.val = 0
 head1.next = one1
 newhead = mergeTwoLists(head, head1)
 while newhead:
 print(newhead.val, )
 newhead = newhead.next
 
 |