這道題,用歸併可太秀了。學習一下鍊錶歸併的寫法(遞迴,最好也要知道飛遞迴寫法)
關於對鍊錶歸併遞迴解法的理解,這一篇講得好:
一看就會,一寫就廢?詳解遞迴非遞迴解法就是迭代,穿針引線,改變指標。最好設定乙個哨兵節點,操作方便。在「21. 合併兩個有序鍊錶」這一題中自己寫了一遍,感覺不夠優雅,看看別人是怎麼寫的。
//歸併解法,堆解法也要會
class solution
listnode mergesort(listnode lists,int left,int right)
listnode merge(listnode l1,listnode l2)
else
}}
23 合併K個公升序鍊錶
給你乙個鍊錶陣列,每個鍊錶都已經按公升序排列。請你將所有鍊錶合併到乙個公升序鍊錶中,返回合併後的鍊錶。示例 1 輸入 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 ...
23 合併K個公升序鍊錶
題目描述 給你乙個鍊錶陣列,每個鍊錶都已經按公升序排列。請你將所有鍊錶合併到乙個公升序鍊錶中,返回合併後的鍊錶。示例 1 輸入 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...
23 合併K個公升序鍊錶
給你乙個鍊錶陣列,每個鍊錶都已經按公升序排列。請你將所有鍊錶合併到乙個公升序鍊錶中,返回合併後的鍊錶。示例 1 輸入 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 ...