C语言 最大堆排序
来源:互联网 发布:eclipse java开发教程 编辑:程序博客网 时间:2024/05/16 11:40
#include<iostream>using namespace std;int left(int i){return 2*i;}int right(int i){return 2*i+1;}int parent(int i){return i/2;}void maxHeapify(int *arr, int length, int i){if(arr == 0 || i < 0){return ;}int l = left(i);int r = right(i);int largest = i;if(l <= length && arr[l-1] > arr[largest-1]){largest = l;}if(r <= length && arr[r-1] > arr[largest-1]){largest = r;}if(largest != i){int temp = arr[i-1];arr[i-1] = arr[largest-1];arr[largest-1] = temp;maxHeapify(arr, length, largest);}}void buildMaxHeap(int *arr, int length){if(arr == 0 || length <= 0){return;}for(int i=length/2; i>=1; i--){maxHeapify(arr, length, i);}}void maxHeapSort(int *arr, int length){if(arr == 0 || length <= 0){return;}int temp;<pre name="code" class="cpp"> buildMaxHeap(arr, i-1);for(int i=length; i>1; i--){temp = arr[i-1];arr[i-1] = arr[0];arr[0] = temp;
$length -= 1;
maxHeapify($arr, 1, $length);}}int main(){int arr[7] = {2, 3, 5, 1, 8, 6, 4};maxHeapSort(arr, 7);for(int i=0; i<7; i++){printf("%d\n", arr[i]);}return 0;}
1 0
- C语言 最大堆排序
- c 最大堆排序
- 堆排序----C语言
- 堆排序C语言
- c语言堆排序
- 堆排序 ----- C语言
- C语言堆排序
- 堆排序c语言
- 堆排序(C语言)
- 堆排序算法(C语言)
- 堆排序C语言实现
- 堆排序C语言实现
- 堆排序C语言实现
- 堆排序C语言实现
- 堆排序C语言代码
- 堆排序--C语言实现
- C语言实现堆排序
- 堆排序--C语言实现
- dyx-- Maximum Subsequence Sum (25)
- 几个栈的应用;;
- c学习笔记(三)C数据类型与运算符
- Learning C++ by Creating Games With UE4(15.05.21)(Chapter 11-3)Monster
- qt 扁平化登陆注册页面
- C语言 最大堆排序
- Oracle数据库、实例、用户、表空间、表之间的关系
- 正则表达式
- C++ 私有成员变量的理解
- 内核分配大块连续内存的方法
- 在程序A中阻塞式的调用、执行程序B
- 循环结构
- 习题3—45
- 开启andriod手机的adbd,进行无线adb调试