隨筆 合併K個排序鍊錶

2021-09-10 13:43:03 字數 889 閱讀 7167

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

示例:輸入:

[1->4->5,

1->3->4,

2->6

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

思路:建立乙個新表頭,然後將所有鍊錶元素按照大小加入到新的鍊錶中;

**實現:

/**

* definition for singly-linked list.

* public class listnode

* }*/class

solution

int i=0;

listnode head=

newlistnode(0

);//新煉表表頭

listnode pre=head;

//新鍊錶最後乙個不為空的元素

int tmp=-1

;//記住每一輪當前最小值的座標

while

(iif(lists[i]

!=null)

else}}

if(i==lists.length-1)

pre.next=lists[tmp]

; pre=pre.next;

lists[tmp]

=lists[tmp]

.next;

//已經加入新鍊錶,原煉表表頭後移

tmp=-1

; i=-1

;//下面會加一次,變為0,開始下一輪迴圈;

} i++;}

return head.next;

//返回去掉我們新增的表頭後的鍊錶

}}

合併k個排序鍊錶

合併k個排序鍊錶,並且返回合併後的排序鍊錶。嘗試分析和描述其複雜度。樣例 給出3個排序鍊錶 2 4 null,null,1 null 返回 1 2 4 null 兩兩合併 合併ab得到c 合併cd得到e definition for listnode.public class listnode pu...

合併K個排序鍊錶

從21.合併兩個有序鍊錶的基礎上,我們已經能夠解決兩個有序鍊錶的問題,現在是k個有序鍊錶,我們可以將第一二個有序鍊錶進行合併,然後將新的有序鍊錶再繼續跟第三個有序鍊錶合併,直到將所有的有序鍊錶合併完成。這樣做思路上是可行的,但是演算法的時間複雜度將會很大,具體就不計算了。有興趣的自己計算下。根據思路...

合併K個排序鍊錶

題目 合併 k 個排序鍊錶,返回合併後的排序鍊錶。請分析和描述演算法的複雜度。示例 輸入 1 4 5,1 3 4,2 6 輸出 1 1 2 3 4 4 5 6 思路 設定乙個堆,每次把每個鍊錶的頭結點放入堆中。記錄每個節點的值與在原陣列中的位置,便於鍊錶往下走。彈出堆中最小值,把最小值所在位置的陣列...