引言
堆排序對於數組最差情況和最後情況都是一樣的效率,都是的時間複雜度。
正文
未完。。。
代碼實現
#include<iostream>
using namespace std;
void heapify(int *a,int n,int k){
int son,temp;
son=k*2+1;
temp=a[k];
while(son<=n){
if(son+1<=n&&a[son]<a[son+1]){
son++;
}
if(temp>=a[son])
break;
else{
a[(son-1)/2]=a[son];
a[son]=temp;
son=son*2+1;
}
}
}
void buildheap(int *a,int n){
for(int i=n/2-1;i>=0;i--){
heapify(a,n-1,i);
}
}
void heapSort(int *a,int n){
int temp;
buildheap(a,n);
for(int i=n-1;i>0;i--){
temp=a[0];
a[0]=a[i];
a[i]=temp;
heapify(a,i-1,0);
}
}
int main(){
int a[15]={6,10,4,5,1,12,14,23,15,21,17,11,19,3,8};
heapSort(a,15);
for(int i=0;i<15;i++){
cout<<a[i]<<endl;
}
return 0;
}