算法学习之堆排序

void Swap(int *i, int *j)
{
    int temp = *i;
    *i = *j;
    *j = temp;
}

void MinHeapFixup(int a[], int i)  
{  
    for (int j = (i - 1) / 2; (j >= 0 && i != 0)&& a[i] > a[j]; i = j, j = (i - 1) / 2)  
        Swap(&a[i], &a[j]);  
}

//在最小堆中加入新的数据nNum  
void MinHeapAddNumber(int a[], int n, int nNum)  
{  
    a[n] = nNum;  
    MinHeapFixup(a, n);  
} 

//  从i节点开始调整,n为节点总数 从0开始计算 i节点的子节点为 2*i+1, 2*i+2  
void MinHeapFixdown(int a[], int i, int n)  
{  
    int j, temp;  
    
    temp = a[i];  
    j = 2 * i + 1;  
    while (j < n)  
    {  
        if (j + 1 < n && a[j + 1] < a[j]) //在左右孩子中找最小的  
            j++;  
        
        if (a[j] >= temp)  
            break;  
        
        a[i] = a[j];     //把较小的子结点往上移动,替换它的父结点  
        i = j;  
        j = 2 * i + 1;  
    }  
    a[i] = temp;  
}  
//在最小堆中删除数  
void MinHeapDeleteNumber(int a[], int n)  
{  
    Swap(&a[0], &a[n - 1]);  
    MinHeapFixdown(a, 0, n - 1);  
}

void MinheapsortTodescendarray(int a[], int n)  
{  
    for (int i = n - 1; i >= 1; i--)  
    {  
        Swap(&a[i], &a[0]);  
        MinHeapFixdown(a, 0, i);  
    }  
} 

void prf(int *arr, int len)
{
    for (int i = 0; i < len; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
}

void Heapsort(int a[], int n)
{
    MinheapsortTodescendarray(a,n);
    
    int temp;
    for(int i = n - 1; i > 1; i--)
    {
        temp = a[0];
        a[0] = a[i];
        a[i] = temp;
        MinheapsortTodescendarray(a, i);
    }
    prf(a, n);
}
原文地址:https://www.cnblogs.com/wustlj/p/2717158.html