堆排序算法实现

#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
void swap(int *arr,int a,int b){
    int temp=arr[a];
    arr[a]=arr[b];
    arr[b]=temp;

}

//按大小调整父子节点位置

void adjustDown(int *arr,int i,int n){
    int j=2*i + 1;
    while(j<n){
        if(j+1 < n && arr[j]>arr[j+1]){
            j++;
        }
        if(arr[i] < arr[j]){
            break;
        }
        swap(arr,i,j);
        i=j;
        j=2*i + 1;
    }
}


//初始建堆

void makeHeap(int *arr,int n){
    int i=0;
    for(i=n/2-1;i>=0;i--){
        adjustDown(arr,i,n);
    }
}

void HeapSort(int *arr,int n){
    int i=0;
    makeHeap(arr,n);

    for(i=n-1;i>0;i--){

       //交换堆顶和末尾元素

        swap(arr,0,i);

        //交换后剩余的堆在进行调整,以满足堆的特性

        adjustDown(arr,0,i);
    }
}

void main(){
    int a[20]={10,3,3,20,8,9,30,4,50,12,14,7,2,60,3,80,100,9,4,2};
    //int a[8]={10,3,3,20,8,9,30,4};
    int len = 20;
    HeapSort(a,len);
    for(int i=0;i<len;i++){
        printf("%d,",a[i]);
    }
    Sleep(15000);

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值