资源简介
算法导论之堆排序,C语言实现版

代码片段和文件信息
#include
// heap sort
int heapSize = 0;
#define SWAP_INT(ab) { a = a + b ; b = a - b ; a = a - b; }
/*
* Max-Heapify
*
* l <-- LEFT(i)
* r <-- RIGHT(i)
* if(l <= heap-size[A] and A[l] > A[i])
* then largest <-- l
* else largest <-- i
* if(r <= heap-size[A] and A[r] < A[largest])
* then largest <-- r
* if largest != i
* then exchange A[i] <--> A[largest]
* Max-Heapify(Alargest)
*/
void MaxHeapify(int * arraySortint i)
{
int l = 2*i+1;
int r = 2*i+2;
int largest = 0;
if (l < heapSize && arraySort[l] > arraySort[i])
{
largest = l;
}
else largest = i;
if (r < heapSize && arraySort[r] > arraySort[largest])
{
largest = r;
}
if (largest != i)
{
SWAP_INT(arraySort[i]arraySort[largest])
MaxHeapify(arraySortlargest);
}
}
void HeapSort(int * arraySortint arrayLen)
{
//build max heap
int i = arrayLen / 2;
heapSize = arrayLen;
for ( ; i >= 0 ; i--)
{
MaxHeapify(arraySorti);
}
//sort
for (i = arrayLen - 1 ; i >= 1 ; i--)
{
SWAP_INT(arraySort[0]arraySort[i])
heapSize--;
MaxHeapify(arraySort0);
}
}
int main()
{
int arrarSort[10] = {4132169101487};
HeapSort(arrarSort10);
for (int i = 0 ; i < 10 ; i++)
{
printf(“%d“arrarSort[i]);
}
return 0;
}
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 1329 2013-01-05 16:55 chapter6\chapter6\chapter6.cpp
文件 3940 2013-01-05 15:49 chapter6\chapter6\chapter6.vcproj
文件 1427 2013-01-05 16:57 chapter6\chapter6\chapter6.vcproj.VNKSKTWA366OGZL.Administrator.user
文件 289792 2013-01-05 16:57 chapter6\chapter6.ncb
文件 890 2013-01-05 15:49 chapter6\chapter6.sln
..A..H. 9216 2013-01-05 16:57 chapter6\chapter6.suo
目录 0 2013-01-05 16:57 chapter6\chapter6
目录 0 2013-01-05 16:57 chapter6
----------- --------- ---------- ----- ----
306594 8
- 上一篇:C++钩子模仿按键精灵屏幕录制
- 下一篇:C++ 坐标点数据转shp矢量数据
相关资源
- 操作系统c语言模拟文件管理系统844
- C语言开发实战宝典
- C++中头文件与源文件的作用详解
- C语言代码高亮html输出工具
- 猜数字游戏 c语言代码
- C语言课程设计
- 数字电位器C语言程序
- CCS FFT c语言算法
- 使用C语言编写的病房管理系统
- 通信过程中的RS编译码程序(c语言)
- 计算机二级C语言上机填空,改错,编
- 用回溯法解决八皇后问题C语言实现
- 简易教务管理系统c语言开发文档
- 操作系统课设 读写者问题 c语言实现
- 小波变换算法 c语言版
- C流程图生成器,用C语言代码 生成C语
- 3des加密算法C语言实现
- 简单的C语言点对点聊天程序
- 单片机c语言源程序(51定时器 八个按
- 个人日常财务管理系统(C语言)
- c语言电子商务系统
- 小甲鱼C语言课件 源代码
- 将图片转换为C语言数组的程序
- C语言实现的一个内存泄漏检测程序
- DES加密算法C语言实现
- LINUX下命令行界面的C语言细胞游戏
- 用单片机控制蜂鸣器播放旋律程序(
- 学校超市选址问题(数据结构C语言版
- 电子时钟 有C语言程序,PROTEUS仿真图
- 尚观培训linux许巍老师关于c语言的课
评论
共有 条评论