Intuition
We are given k sorted lists and need to merge them all in one single linked list.
Let’s dive deeper into some observations. One way to brute force this would be to iterate over all k
lists, have another loop which moves over the start pointers for all lists and updates them.
One efficient way to approach this would be to introduce a min-heap
. A min heap is a tree like data structure where the parent nodes are smaller than the child nodes. This would mean the top-most element in a min-heap would be the smallest element in the data.
We can use this feature and insert all the list starting nodes into the min-heap so we get the list node with smallest value at heap[0]
. We can then pop this element and insert heap[0].next
into the heap - if it exists.
This needs to keep happen until len(heap) > 0
. Fairly straight forward algorithm - but a very clever application of a heap.
Code
Python3
Big O Analysis
-
Runtime
The runtime complexity here is since we are reducing our search space of size K in half (rates) but for every rate that we test - we also iterate the entire array of size N.
-
Memory
The memory usage is since we use a heap to store list nodes.
— A