资源简介
算法导论之堆排序,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语言编程ftp程序,并实现基本功能
- 信道编码的C语言程序
- 嵌入式C语言技术实战开发一书源代码
- C语言实现农历万年历,农历公历转换
- Windows下C语言实现文件、文件夹的复制
- C语言课程设计报告 代码 小学算术运
- HMC5883驱动,C语言
- c语言实现离散的真值表判断、并交差
- Linux- 用C语言实现的简单Web服务器源代
- LIVE555源码C语言格式
- 表达式求值求后缀c语言
- 图的深度优先遍历C语言数据结构
- 哈夫曼编码系统C语言实现
- 函数信号发生器c语言
- P2PDemo使用C语言实现的P2P源码
- FFT/IFFT变换C语言代码,包含浮点型C工
- STM32-C语言知识点
- C语言编写的家谱代码
- 51单片机用C语言取出奇偶校验位
- 医务室的模拟 c语言 数据结构
- 0-1背包问题C语言源码
- C语言程序设计教程(第2版)_杨路明
- 数据结构哈夫曼编码译码C语言版程序
- AES、DES加密算法C语言源码
- 旋转编码开关C语言单片机开发
- IIC C语言编程实现单片机与存储器的数
- 基于数据结构c语言实现的银行叫号系
- 迷宫求解算法数据结构c语言
- welch功率谱的c语言程序.txt
- c语言模拟进程
评论
共有 条评论