leetcode 23 合併K個排序鍊錶

2021-10-01 15:21:04 字數 923 閱讀 9216

合併 k 個排序鍊錶,返回合併後的排序鍊錶。請分析和描述演算法的複雜度。

示例:輸入:

1->4->5,

1->3->4,

2->6

輸出: 1->1->2->3->4->4->5->6

基本思路:我們可以使用分治思想 來解決這個問題。當乙個鍊錶集合中需要合併並排序。我們可以假設只有2個 每次合併兩個。兩個合併乙個。這樣就可以獲取到最終的結果。

第一次將list[0]與list[len-1]合併 2次list[1]與list[len-2] 經過 for迴圈一次後。可以等到一半的list鍊錶結合。在依次len = len/2; 依次合併 就可以獲取到下標為0的為頭結點的這個鍊錶。

//合併兩個有序的鍊錶

public listnode mergeklists

(listnode[

] lists)

len =

(len+1)

/2;}

return lists[0]

;}//合併兩個有序的鍊錶

private listnode merageklist

(listnode l1, listnode l2)

else

head = head.next;}if

(l1 != null)

else

return listnode.next;

//note 注意返回的不是head 返回head 會帶有 -1這個結點的值 只需要後邊的值 牛掰思想

}

時間複雜度:整體時間複雜度為o(n*log(k)), k為鍊錶個數,n為鍊錶平均長度。

分治實現LeetCode 23題 合併K個排序鍊錶

紀念第一道沒有看題解做出來的困難題 分治思想 歸併排序實現合併k個排序鍊錶 由於是實現一連串已經排序的鍊錶,所以第一時間想到了歸併排序 又由於是實現多個鍊錶的總排序,為了減少時間複雜度又想到了分治思想,這一題中也就是二分法 做了這麼多天的題總算有點進步 class solution 結果陣列的頭結點...

LeetCode 23 合併 K個排序序列

合併 k 個排序鍊錶,返回合併後的排序鍊錶。請分析和描述演算法的複雜度。示例 輸入 1 4 5,1 3 4,2 6 輸出 1 1 2 3 4 4 5 6 解題思路 採用分治的思想,將 k 個鍊錶的合併問題轉換成,合併 2 個有序鍊錶的問題 typedef struct listnode list 定...

Leetcode23 合併K個排序鍊錶

題目 解題思路 這道題使用的是分治演算法。首先還用輔助函式mergetwolists 用來合併兩個有序單鏈表,不申請額外的空間實現原地合併。如下 listnode mergetwolists listnode l1,listnode l2 else head nexthead while l1 nu...