基础排序之堆排序(C语言小堆版)

堆排序

成都创新互联公司是一家专注于网站制作、做网站与策划设计,江汉网站建设哪家好?成都创新互联公司做网站,专注于网站建设十余年,网设计领域的专业建站公司;建站业务涵盖:江汉等地区。江汉做网站价格咨询:18980820575

#include
typedef int ElementType;
int arr1[11]={0,2,87,39,49,34,62,53,6,44,98};

void Swap(int* a,int* b)
{
    int temp=*a;
    *a=*b;
    *b=temp;
}

void PercDown(int  A[], int i, int N)
{
    int child;
    ElementType Tmp;

    for (Tmp = A[i]; 2*i+1 < N; i = child){
        child = 2*i+1; //注意数组下标是从0开始的,所以左孩子的求发不是2*i
        if (child != N - 1 && A[child + 1] > A[child])
            ++child;                //找到最大的儿子节点
        if (Tmp < A[child])
            A[i] = A[child];
        else
            break;
    }
    A[i] = Tmp;
}

void HeapSort(int A[], int N)
{
    int i;
    for (i = N / 2; i >= 0; --i)
        PercDown(A, i, N);    //构造堆
    for(i=N-1;i>0;--i)
    {
        Swap(&A[0],&A[i]);        //将最大元素(根)与数组末尾元素交换,从而删除最大元素,重新构造堆
        PercDown(A, 0, i);
    }
}

void Print(int A[],int N)
{
    int i;
    for(i=0;i

本文名称:基础排序之堆排序(C语言小堆版)
链接分享:http://bzwzjz.com/article/jgosdd.html
Copyright © 2007-2020 广东宝晨空调科技有限公司 All Rights Reserved 粤ICP备2022107769号
友情链接: 成都网站设计 手机网站设计 成都网站制作 成都商城网站建设 网站设计制作 成都网站设计公司 成都网站建设 成都定制网站建设 网站设计 企业网站设计 重庆手机网站建设 成都网站制作 成都网站建设 成都网站设计 网站建设公司 重庆网站建设 移动网站建设 成都网站建设 重庆企业网站建设 成都网站制作 网站建设方案 响应式网站设计