代码拉取完成,页面将自动刷新
#include<stdio.h>
int h[101];
int n;
void swap(int x, int y){
int t;
t = h[x];
h[x] = h[y];
h[y] = t;
return ;
}
void siftdown(int i){
int flag = 0;
int t;
while(flag == 0 && i * 2 <= n){
if(h[i] < h[i * 2]){
t = i * 2;
}
else{
t = i;
}
if(i * 2 + 1 <= n){
if(h[t] < h[i * 2 + 1]){
t = i * 2 + 1;
}
}
if(t != i){
swap(t, i);
i = t;
}
else{
flag = 1;
}
}
return ;
}
void creat(){
int i;
for(i = n / 2;i >= 1;i --){
siftdown(i);
}
return;
}
int main(){
int i, num;
scanf("%d", &num);
for(i = 1;i <= num;i ++){
scanf("%d", &h[i]);
}
n = num;
creat();
for(int i = 1;i <= num;i ++){
printf("%d ", h[i]);
}
printf("\n");
return 0;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。