File tree Expand file tree Collapse file tree 1 file changed +37
-0
lines changed Expand file tree Collapse file tree 1 file changed +37
-0
lines changed Original file line number Diff line number Diff line change
1
+ /**
2
+ * Definition for singly-linked list.
3
+ * class ListNode {
4
+ * val: number
5
+ * next: ListNode | null
6
+ * constructor(val?: number, next?: ListNode | null) {
7
+ * this.val = (val===undefined ? 0 : val)
8
+ * this.next = (next===undefined ? null : next)
9
+ * }
10
+ * }
11
+ */
12
+
13
+ function mergeKLists ( lists : Array < ListNode | null > ) : ListNode | null {
14
+ if ( ! lists || lists . length === 0 ) return null ;
15
+
16
+ const minHeap = new PriorityQueue ( ( a : ListNode , b : ListNode ) => a . val - b . val ) ;
17
+
18
+ for ( const node of lists ) {
19
+ if ( node ) minHeap . enqueue ( node ) ;
20
+ }
21
+
22
+ const dummyHead = new ListNode ( ) ;
23
+ let current = dummyHead ;
24
+
25
+ while ( ! minHeap . isEmpty ( ) ) {
26
+ const minimumElement = minHeap . dequeue ( ) ;
27
+
28
+ current . next = minimumElement ;
29
+ current = current . next ;
30
+
31
+ if ( minimumElement . next ) {
32
+ minHeap . enqueue ( minimumElement . next ) ;
33
+ }
34
+ }
35
+
36
+ return dummyHead . next ;
37
+ }
You can’t perform that action at this time.
0 commit comments