【LeetCode每天一题】 Merge k Sorted Lists(合并K个有序链表)

Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity.

Example:Input:

[
  1->4->5,
  1->3->4,
  2->6
]
Output: 1->1->2->3->4->4->5->6

思路

  这道题最简单的方法就是我们将K个链表中的所有数据都存进数组中,然后对数据进行排序。排序完毕之后在依此对数组中的数据进行链表的构造。时间复杂度为O(n log n),n 是链表元素的总和。
  第二种思路是我们我们可以将列表中两个链表两个链表进行合并,直到最后合并完只剩下一条链表,就是排序之后的链表。时间复杂度为O(Nlog k)(N是总的元素数),空间复杂度为O(1)。
第二种图示

第一种方法的解决代码

 1 class Solution(object):
 2     def mergeKLists(self, lists):
 3         """
 4         :type lists: List[ListNode]
 5         :rtype: ListNode
 6         """
 7         self.nodes = []
 8         head = point = ListNode(0)    # 设置哨兵节点
 9         for l in lists:                  # 循环遍历列表中每一个链表,将元素添加进数组。
10             while l:                     # 将当前链表中的元素进行添加
11                 self.nodes.append(l.val)
12                 l = l.next
13         for x in sorted(self.nodes):          # 将排序之后的数组中的元素,构造链表。
14             point.next = ListNode(x)
15             point = point.next
16         return head.next

第二种方法的解决代码


 

 1 class Solution(object):
 2     def mergeKLists(self, lists):
 3         """
 4         :type lists: List[ListNode]
 5         :rtype: ListNode
 6         """
 7         amount = len(lists)          # 计算出K的数值
 8         interval = 1                        # 间距
 9         while interval < amount:    # 先从间距1开始合并,
10             for i in range(0, amount - interval, interval * 2): 
11                 lists[i] = self.merge2Lists(lists[i], lists[i + interval])   # 使用两个链表的合并函数进行合并。
12             interval *= 2        # 当上一次间距合并完之后,将间距扩大为2倍。
13         return lists[0] if amount > 0 else lists      # 当列表链表数大于0时,返回第一个链表(排序好的链表)。
14  
15     def merge2Lists(self, l1, l2):         # 两个链表进行合并成一个链表。
16         head = point = ListNode(0)       # 设置哨兵节点
17         while l1 and l2:
18             if l1.val <= l2.val:
19                 point.next = l1
20                 l1 = l1.next
21             else:
22                 point.next = l2
23                 l2 = l1
24                 l1 = point.next.next
25             point = point.next
26         if not l1:                            #  其中一个链表不为空,就将其添加到后面。
27             point.next=l2
28         else:
29             point.next=l1
30         return head.next
posted @ 2019-04-06 16:57  GoodRnne  阅读(800)  评论(0编辑  收藏  举报