#include using namespace std; void heapify(int arr[], int n, int i) { int minimum = i; int left = 2 * i + 1; int right = 2 * i + 2; if (left < n && arr[left] < arr[minimum]) minimum = left; if (right < n && arr[right] < arr[minimum]) minimum = right; if (minimum != i) { swap(arr[i], arr[minimum]); heapify(arr, n, minimum); } } void heapSort(int arr[], int n) { for (int i = n / 2 - 1; i >= 0; i--) heapify(arr, 6, i); for (int i = n - 1; i > 0; i--) { swap(arr[0], arr[i]); heapify(arr, i, 0); } } int main() { int arr[] = { 20, 30, 5, 15, 40,10}; cout << "Original array: "; for(int i=0; i<6; i++) cout << arr[i] << " "; heapSort(arr, 6); cout <