Keep only the largest k values by maintaining a small min-heap.

Algorithm

@steps

  1. Store the heap in an array.
  2. Compare parent and child indexes instead of building explicit tree nodes.
  3. Swap only when the heap order is violated.
  4. Print the deterministic final heap state for replay comparison. @end @complexity
  • Time: O(n log k)
  • Space: O(k) @end
bounded heap For top-k largest values, a min-heap of size k keeps the current cutoff at the root.

Kotlin DSA Implementation

basic.kt
fun listString(values: List<Int>) = values.joinToString(", ", "[", "]")
fun heapInsert(heap: MutableList<Int>, value: Int) {
    heap.add(value)
    var child = heap.lastIndex
    while (child > 0) {
        val parent = (child - 1) / 2
        if (heap[parent] <= heap[child]) break
        val tmp = heap[parent]; heap[parent] = heap[child]; heap[child] = tmp
        child = parent
    }
}
fun heapPop(heap: MutableList<Int>): Int {
    val smallest = heap[0]
    heap[0] = heap.removeAt(heap.lastIndex)
    var parent = 0
    while (true) {
        val left = parent * 2 + 1
        val right = left + 1
        if (left >= heap.size) break
        var child = left
        if (right < heap.size && heap[right] < heap[left]) child = right
        if (heap[parent] <= heap[child]) break
        val tmp = heap[parent]; heap[parent] = heap[child]; heap[child] = tmp
        parent = child
    }
    return smallest
}
fun main() { val heap = mutableListOf<Int>(); for (value in listOf(5, 1, 9, 3, 7, 2)) { heapInsert(heap, value); if (heap.size > 3) heapPop(heap) }; val top = heap.sortedDescending(); println(listString(top)) }

@end @output [9, 7, 5] @end