数据结构----------实现最小堆排序
原理: 来源于---------------趣味数据结构 代码:
#include<stdio.h>
#include<stdlib.h>
#define N 65535
int r[N] = { -1,1,4,590,4,2,8,7,5,89,67,5,2,1,67,86,54 };
void swap(int i, int j) {
int temp = r[i];
r[i] = r[j];
r[j] = temp;
}
void sink(int k, int n,int flag) {
int j = 0;
while (2 * k <= n) {
j = 2 * k;
if (flag == 0) {
if (j<n&&r[j + 1]>r[j])
j++;
if (r[k] < r[j])
swap(k, j);
else
break;
}
else {
if (j<n&&r[j + 1]<r[j])
j++;
if (r[k] > r[j])
swap(k, j);
else
break;
}
k = j;
}
}
void heapSort(int n,int flag) {
for (int i = n / 2; i > 0; i--) {
sink(i, n,flag);
}
while (n > 1) {
swap(1, n);
n--;
sink(1, n, flag);
}
}
void print() {
for (int i = 1; r[i] != 0; i++) {
printf("%d ", r[i]);
}
}
int main() {
printf("初始的顺序\n--------------\n");
print();
printf("\n最小堆排序后结果\n--------------\n");
heapSort(17, 1);
print();
printf("\n--------------\n");
system("pause");
return 0;
}
测试:
如果存在什么问题欢迎提出指正!谢谢!
|