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.

C++ DSA Implementation

basic.cpp
#include <algorithm>
#include <iostream>
#include <sstream>
#include <vector>
using namespace std;
string listString(const vector<int>& values) {
    stringstream out; out << "[";
    for (size_t i = 0; i < values.size(); i++) { if (i) out << ", "; out << values[i]; }
    out << "]"; return out.str();
}
void heapInsert(vector<int>& heap, int value) {
    heap.push_back(value);
    size_t child = heap.size() - 1;
    while (child > 0) {
        size_t parent = (child - 1) / 2;
        if (heap[parent] <= heap[child]) break;
        swap(heap[parent], heap[child]);
        child = parent;
    }
}
int heapPop(vector<int>& heap) {
    int smallest = heap[0];
    heap[0] = heap.back(); heap.pop_back();
    size_t parent = 0;
    while (true) {
        size_t left = parent * 2 + 1, right = left + 1;
        if (left >= heap.size()) break;
        size_t child = left;
        if (right < heap.size() && heap[right] < heap[left]) child = right;
        if (heap[parent] <= heap[child]) break;
        swap(heap[parent], heap[child]);
        parent = child;
    }
    return smallest;
}
int main() { vector<int> heap; for (int value : {5, 1, 9, 3, 7, 2}) { heapInsert(heap, value); if (heap.size() > 3) heapPop(heap); } sort(heap.begin(), heap.end(), greater<int>()); cout << listString(heap) << "\n"; }

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