使用c语言写一个堆排序
时间: 2023-03-11 08:18:42 浏览: 130
我可以给你一个示例:
#include <stdio.h>
// 堆排序函数
void heapSort(int arr[], int n)
{
// 建立堆
for (int i = n / 2 - 1; i >= 0; i--)
heapify(arr, n, i);
// 从堆中取出元素,并继续堆化
for (int i=n-1; i>=0; i--)
{
// 将堆顶元素与堆尾元素交换
int temp = arr[0];
arr[0] = arr[i];
arr[i] = temp;
// 堆化剩下的元素
heapify(arr, i, 0);
}
}
// 堆化函数
void heapify(int arr[], int n, int i)
{
int largest = i; // 初始化最大值为根节点
int l = 2*i + 1; // 左子树的索引
int r = 2*i + 2; // 右子树的索引
// 如果左子树的索引大于堆的大小,说明左子树已经不在堆中
if (l < n && arr[l] > arr[largest])
largest = l;
// 如果右子树的索引大于堆的大小,说明右子树已经不在堆中
if (r < n && arr[r] > arr[largest])
largest = r;
// 如果最大值不是根节点,交换它们
if (largest != i)
{
int swap = arr[i];
arr[i] = arr[largest];
arr[largest] = swap;
// 递归地堆化子树
heapify(arr, n, largest);
}
}
// 打印函数
void printArray(int arr[], int n)
{
for (int i=0; i<n; ++i)
printf("%d ",arr[i]);
printf("\n");
}
// 主函数
int main()
{
int arr[] = {12, 11, 13, 5, 6, 7};
int n = sizeof(arr)/sizeof(arr[0]);
heapSort(arr, n);
printf("排序后的数组: \n");
printArray(arr, n);
}
阅读全文