Add initial cpp heapsort, needs refactor (likely use constexpr)

This commit is contained in:
2025-10-08 12:12:00 -05:00
parent 6d84849ce8
commit 50873ce450
5 changed files with 138 additions and 0 deletions

View File

@@ -0,0 +1,2 @@
namespace dlos {
}

View File

@@ -0,0 +1,23 @@
#pragma once
#include "../data_structures/heap.hpp"
namespace dlos {
template<typename T, size_t N>
void heapsort(std::array<T, N> &a) {
dlos::Heap<T, N> heap = dlos::Heap<T, N>(a);
heap.maxHeap();
heapsort(heap);
}
template<typename T, size_t N>
void heapsort(Heap<T, N> &heap) {
for (int i = heap.size - 1; i > 0; i--) {
heap.nodeSwap(0, i);
heap.size -= 1;
heap.siftDown(0);
}
}
}