手机
当前位置:查字典教程网 >编程开发 >C语言 >C语言实现堆排序的简单实例
C语言实现堆排序的简单实例
摘要:本文通过一个C语言实现堆排序的简单实例,帮助大家抛开复杂的概念,更好的理解堆排序。实例代码如下:voidFindMaxInHeap(inta...

本文通过一个C语言实现堆排序的简单实例,帮助大家抛开复杂的概念,更好的理解堆排序。

实例代码如下:

void FindMaxInHeap(int arr[], const int size) { for (int j = size - 1; j > 0; --j) { int parent = j / 2; int child = j; if (j < size - 1 && arr[j] < arr[j+1]) { ++child; } if (arr[child] > arr[parent]) { int tmp = arr[child]; arr[child] = arr[parent]; arr[parent] = tmp; } } } void HeapSort(int arr[], const int size) { for (int j = size; j > 0; --j) { FindMaxInHeap(arr, j); int tmp = arr[0]; arr[0] = arr[j - 1]; arr[j - 1] = tmp; } } int main() { int arr[] = {2, 5, 3, 12, 6, 21, 8, 1}; int n = sizeof(arr) / sizeof(arr[0]); HeapSort(arr, n); for (int j = 0; j < n; ++j) { printf("%3d",arr[j]); } printf("n"); return 0; }

【C语言实现堆排序的简单实例】相关文章:

用c语言实现2000内既能被3整除又能被7整除的个数

用c语言实现冒泡排序,选择排序,快速排序

基于C中一个行压缩图的简单实现代码

C语言 实现N阶乘的程序代码

新旧MFC版本实现CEdit透明的2种方法的实例代码

C语言程序设计50例(经典收藏)

C 字符串数组排序的小例子

C语言小程序 杨辉三角示例代码

C语言 扩展欧几里得算法代码

C语言编写银行打印程序实例参考

精品推荐
分类导航