题目
给你一个链表数组,每个链表都已经按升序排列。
请你将所有链表合并到一个升序链表中,返回合并后的链表。
示例
输入:lists = [[1,4,5],[1,3,4],[2,6]]
输出:[1,1,2,3,4,4,5,6]
解释:链表数组如下:
[
1->4->5,
1->3->4,
2->6
]
将它们合并到一个有序链表中得到。
1->1->2->3->4->4->5->6
解析
根据二维数组的长度,从中间开始分成两部分,不断递归,然后分别调用两两合并的那个函数
/**
* Definition for singly-linked list.
* type ListNode struct {
* Val int
* Next *ListNode
* }
*/
func mergeTwoLists1(list1 *ListNode, list2 *ListNode) *ListNode {
dummy := &ListNode{}
pre := dummy
for list1 != nil && list2 != nil {
if list1.Val <= list2.Val {
pre.Next = list1
list1 = list1.Next
} else {
pre.Next = list2
list2 = list2.Next
}
pre = pre.Next
}
if list1 != nil {
pre.Next = list1
}
if list2 != nil {
pre.Next = list2
}
return dummy.Next
}
func mergeKLists(lists []*ListNode) *ListNode {
n := len(lists)
if n == 0 {
return nil
}
if n == 1 {
return lists[0]
}
left := mergeKLists(lists[:n/2])
right := mergeKLists(lists[n/2:])
res := mergeTwoLists1(left, right)
return res
}