In: Computer Science
I need step by step instructions of inserting these into a heap.
this, is, the, house, that, jack, built. They should be inserted in
this sequence. THen swap the first and last variables and do it
again. I know the answer is suppose to be but not sure how I'm
suppose to get that answer.   
2nd iteration would be.   built, is, the house, that
jack, this.
I know the ansers in array format would be just keep getting it
wrong on my own:
1. built | is | house | this | that | the | jack
2. built | house | jack | is | that | the | this
#include <bits/stdc++.h>
using namespace std;
// To heapify a subtree rooted with node i which is
// an index in arr[]. n is size of heap
void heapify(string arr[], int n, int i)
{
        int largest = i; // Initialize largest as root
        int l = 2 * i + 1; // left = 2*i + 1
        int r = 2 * i + 2; // right = 2*i + 2
        // If left child is larger than root
        if (l < n && arr[l] > arr[largest])
                largest = l;
        // If right child is larger than largest so far
        if (r < n && arr[r] > arr[largest])
                largest = r;
        // If largest is not root
        if (largest != i)
        {
                swap(arr[i], arr[largest]);
                // Recursively heapify the affected sub-tree
                heapify(arr, n, largest);
        }
}
// main function to do heap sort
/* A utility function to print array of size n */
void printArray(string arr[], int n)
{
        for (int i = 0; i < n; ++i)
                cout << arr[i] << " ";
        cout << "\n";
}
void heapSort(string arr[], int n)
{
        // Build heap (rearrange array)
        for (int i = n / 2 - 1; i >= 0; i--)
                heapify(arr, n, i);
        // One by one extract an element from heap
        for (int i = n - 1; i > 0; i--)
        {
                printArray(arr, n);
                // Move current root to end
                swap(arr[0], arr[i]);
                // call max heapify on the reduced heap
                heapify(arr, i, 0);
        }
}
// Driver program
int main()
{
        string arr[] = { "this", "is", "the", "house", "that", "jack", "built"};
        int n = sizeof(arr) / sizeof(arr[0]);
        heapSort(arr, n);
        printArray(arr, n);
}
OUTPUT:
