堆排序——华农oj8644

8644 堆排序
时间限制:1000MS 代码长度限制:10KB
提交次数:1909 通过次数:1257

题型: 编程题 语言: G++;GCC
Description
用函数实现堆排序,并输出每趟排序的结果

输入格式
第一行:键盘输入待排序关键的个数n
第二行:输入n个待排序关键字,用空格分隔数据

输出格式
第一行:初始建堆后的结果
其后各行输出交换堆顶元素并调整堆的结果,数据之间用一个空格分隔

输入样例
10
5 4 8 0 9 3 2 6 7 1

输出样例
9 7 8 6 4 3 2 5 0 1
8 7 3 6 4 1 2 5 0 9
7 6 3 5 4 1 2 0 8 9
6 5 3 0 4 1 2 7 8 9
5 4 3 0 2 1 6 7 8 9
4 2 3 0 1 5 6 7 8 9
3 2 1 0 4 5 6 7 8 9
2 0 1 3 4 5 6 7 8 9
1 0 2 3 4 5 6 7 8 9
0 1 2 3 4 5 6 7 8 9

//堆排序 
#include
#include
#include
#define maxn 10010
int ap[maxn];
void swap(int &a,int &b)
{
	int t=a;
	a=b;
	b=t;
}
//建立最大堆,由于每次取最大元素反正末尾,就相当于顺着按递增顺序排 
void dot(int ap[],int i,int n)
{
	int each,j,tmp=ap[i];
	for(j=i;j*2<=n;j=each)
	{
		each=j*2;
		if(each!=n&&ap[each]<ap[each+1])each++;
		if(tmp>ap[each])break;
		ap[j]=ap[each];
	}
	ap[j]=tmp;
}
int main()
{
	int i,n;
	scanf("%d",&n);
	for(i=1;i<=n;i++)
	{
		scanf("%d",&ap[i]);
	}
	//建堆 
	for(int i=n/2;i>0;i--)
	{
		dot(ap,i,n);
	}
	for(int i=n;i>=1;i--)
	{
		for(int t=1;t<=n;t++)printf("%d ",ap[t]);
		printf("\n");
		swap(ap[1],ap[i]);
		dot(ap,1,i-1);
	}
	return 0;
} 

你可能感兴趣的:(堆排序)