堆排序
来源:互联网 发布:免费英语网络课程 编辑:程序博客网 时间:2024/06/10 04:20
/*堆排序算法的时间复杂度为O(n*log2n),它为不稳定排序算法,从小到大排序建的堆为大根堆。*/#include <stdio.h>int sum[1100];void shift(int k,int len)//建堆的函数{int i,j,flag,temp;i=k;j=2*k;temp=sum[k];flag=1;while(j<=len&&flag){if(j+1<=len&&sum[j+1]>sum[j])j++;if(sum[j]<=temp)flag=0;else{sum[i]=sum[j];i=j;j=2*j;}}sum[i]=temp;}int main(){int n,i,j,temp;scanf("%d",&n);for(i=1;i<=n;i++)scanf("%d",&sum[i]);for(i=n/2;i>=1;i--)shift(i,n);//初始建堆for(i=n;i>1;i--)//每次交换根与最大下标结点,且调整堆时数组长度减1{temp=sum[1];sum[1]=sum[i];sum[i]=temp;shift(1,i-1);}for(i=1;i<=n;i++)printf("%d ",sum[i]);printf("\n");return 0;}
阅读全文
0 0
- 堆及堆排序
- 堆/堆排序特点
- 【二叉堆、堆排序】
- 二叉堆 & 堆排序
- 二叉堆 & 堆排序
- 堆与堆排序
- 堆与堆排序
- 堆与堆排序
- 堆与堆排序
- 堆与堆排序
- 堆与堆排序
- 堆和堆排序
- 堆排序(最大堆)
- 堆和堆排序
- 堆和堆排序
- 堆及堆排序
- 堆和堆排序
- 堆与堆排序
- AndroidContrentProvider 获取系统联系人数据。
- 442C
- NOIP2016提高组day1
- java方法的调用和数组
- 由字符串生成数组-《数据结构与算法》
- 堆排序
- 日常作业2017-7-19
- 自定义DEBUG
- JS跨页面调用变量的方法
- 16 多校 8
- scrollTop clientTop offsetTop scrollHeight clientHeight clientWidth的区别及用法
- 怎样尊重一个程序员
- CodeVS 1710 生日蛋糕 题解
- 多态应用