博客
关于我
排序——堆排序
阅读量:687 次
发布时间:2019-03-17

本文共 1444 字,大约阅读时间需要 4 分钟。

堆排序代码

#include 
using namespace std;#include
#include
//堆调整,构建大顶堆,arr[]是待调整的数组,i是待调整的数组//元素的位置,length是数组的长度void HeapAdjust(int arr[], int i, int length){ int Child; int temp; for(;2 * i + 1 < length; i = Child) { //子节点的位置 = 2 * (parent(父结点)) + 1 Child = 2 * i + 1; //得到子结点中较大的结点 if(Child < length - 1 && arr[Child + 1] > arr[Child]) ++Child; //如果较大的子结点大于父结点那么把较大的子结点往上移动 //替换它的父结点 if(arr[i] < arr[Child]) { temp = arr[i]; arr[i] = arr[Child]; arr[Child] = temp; } else break; }}//堆排序算法void HeapSort(int arr[], int length){ int i; //调整序列的前半部分元素,调整完之后第一个元素 //是序列的最大元素,length/2-1是最后一个非叶子结点 for(i = length/2 - 1; i >= 0; --i) HeapAdjust(arr, i, length); //从最后一个元素开始对序列进行调整,不断的缩小调整 //的范围直到第一个元素 //循环里是把第一个元素和当前的最后一个元素交换 //保证当前的最后一个位置的元素是现在这个序列的最大的 //不断的缩小调整heap的范围,每一次调整完毕保证第一个 //元素是当前序列的最大的元素 for(i = length - 1; i > 0; --i) { arr[i] = arr[0]^arr[i]; arr[0] = arr[0]^arr[i]; arr[i] = arr[0]^arr[i]; HeapAdjust(arr, 0, i); //递归调整 }}int main() { // insert code here... int a[100]; int c=0; int i=1; scanf("%d",&a[i]); while(a[i]!=0) { //printf("%d %d\n",i,a[i]); i++; scanf("%d",&a[i]); c++; } HeapSort(a, c+2); for(int i=1;i

转载地址:http://rofhz.baihongyu.com/

你可能感兴趣的文章
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>
Mysql中索引的最左前缀原则图文剖析(全)
查看>>
MySql中给视图添加注释怎么添加_默认不支持_可以这样取巧---MySql工作笔记002
查看>>
Mysql中获取所有表名以及表名带时间字符串使用BetweenAnd筛选区间范围
查看>>
Mysql中视图的使用以及常见运算符的使用示例和优先级
查看>>
Mysql中触发器的使用示例
查看>>
Mysql中设置只允许指定ip能连接访问(可视化工具的方式)
查看>>
mysql中还有窗口函数?这是什么东西?
查看>>
mysql中间件
查看>>
MYSQL中频繁的乱码问题终极解决
查看>>
MySQL为Null会导致5个问题,个个致命!
查看>>
MySQL为什么不建议使用delete删除数据?
查看>>
MySQL主从、环境搭建、主从配制
查看>>
Mysql主从不同步
查看>>
mysql主从同步及清除信息
查看>>