第十五周 项目1 排序(堆排序)
2015-12-14 16:24
363 查看
/*
* 烟台大学计算机与控制工程学院
*文件名称:mian.cpp
*作 者:王旭
*完成日期:2015年12月14日
*版 本 号:v1.0
*
*问题描述:堆排序
*
*输入描述:无
*程序输出:无
*/
#include <stdio.h>
#define MaxSize 20
typedef int KeyType; //定义关键字类型
typedef char InfoType[10];
typedef struct //记录类型
{
KeyType key; //关键字项
InfoType data; //其他数据项,类型为InfoType
} RecType; //排序的记录类型定义
//调整堆
void sift(RecType R[],int low,int high)
{
int i=low,j=2*i; //R[j]是R[i]的左孩子
RecType temp=R[i];
while (j<=high)
{
if (j<high && R[j].key<R[j+1].key) //若右孩子较大,把j指向右孩子
j++; //变为2i+1
if (temp.key<R[j].key)
{
R[i]=R[j]; //将R[j]调整到双亲结点位置上
i=j; //修改i和j值,以便继续向下筛选
j=2*i;
}
else break; //筛选结束
}
R[i]=temp; //被筛选结点的值放入最终位置
}
//堆排序
void HeapSort(RecType R[],int n)
{
int i;
RecType temp;
for (i=n/2; i>=1; i--) //循环建立初始堆
sift(R,i,n);
for (i=n; i>=2; i--) //进行n-1次循环,完成推排序
{
temp=R[1]; //将第一个元素同当前区间内R[1]对换
R[1]=R[i];
R[i]=temp;
sift(R,1,i-1); //筛选R[1]结点,得到i-1个结点的堆
}
}
int main()
{
int i,n=10;
RecType R[MaxSize];
KeyType a[]= {0,6,8,7,9,0,1,3,2,4,5};//a[0]空闲,不作为关键字
for (i=1; i<=n; i++)
R[i].key=a[i];
printf("排序前:");
for (i=1; i<=n; i++)
printf("%d ",R[i].key);
printf("\n");
HeapSort(R,n);
printf("排序后:");
for (i=1; i<=n; i++)
printf("%d ",R[i].key);
printf("\n");
return 0;
}
运行结果:
* 烟台大学计算机与控制工程学院
*文件名称:mian.cpp
*作 者:王旭
*完成日期:2015年12月14日
*版 本 号:v1.0
*
*问题描述:堆排序
*
*输入描述:无
*程序输出:无
*/
#include <stdio.h>
#define MaxSize 20
typedef int KeyType; //定义关键字类型
typedef char InfoType[10];
typedef struct //记录类型
{
KeyType key; //关键字项
InfoType data; //其他数据项,类型为InfoType
} RecType; //排序的记录类型定义
//调整堆
void sift(RecType R[],int low,int high)
{
int i=low,j=2*i; //R[j]是R[i]的左孩子
RecType temp=R[i];
while (j<=high)
{
if (j<high && R[j].key<R[j+1].key) //若右孩子较大,把j指向右孩子
j++; //变为2i+1
if (temp.key<R[j].key)
{
R[i]=R[j]; //将R[j]调整到双亲结点位置上
i=j; //修改i和j值,以便继续向下筛选
j=2*i;
}
else break; //筛选结束
}
R[i]=temp; //被筛选结点的值放入最终位置
}
//堆排序
void HeapSort(RecType R[],int n)
{
int i;
RecType temp;
for (i=n/2; i>=1; i--) //循环建立初始堆
sift(R,i,n);
for (i=n; i>=2; i--) //进行n-1次循环,完成推排序
{
temp=R[1]; //将第一个元素同当前区间内R[1]对换
R[1]=R[i];
R[i]=temp;
sift(R,1,i-1); //筛选R[1]结点,得到i-1个结点的堆
}
}
int main()
{
int i,n=10;
RecType R[MaxSize];
KeyType a[]= {0,6,8,7,9,0,1,3,2,4,5};//a[0]空闲,不作为关键字
for (i=1; i<=n; i++)
R[i].key=a[i];
printf("排序前:");
for (i=1; i<=n; i++)
printf("%d ",R[i].key);
printf("\n");
HeapSort(R,n);
printf("排序后:");
for (i=1; i<=n; i++)
printf("%d ",R[i].key);
printf("\n");
return 0;
}
运行结果:
相关文章推荐
- (第十六周项目1)验证算法
- 第一次上趣味编程
- 第十五周项目3 B-树的基本操作
- System.out.println(new String(buf,0,num));
- 第十六周--验证算法(快速排序)
- 大数据全栈式开发语言——Python
- springMVC.xml与springContext.xml关系与区别
- 第15周项目3B-树的基本操作
- PHP中单引号和双引号的区别
- IOS 蓝牙4.0(BLE 协议) 初窥
- python基础教程共60课-第40课用文件保存游戏2
- Formal sys-Pradicate semantic
- 剑指offer系列之四十五:左旋转字符串
- 高效加载Bitmap
- 自动化测试模型总结
- sql server case when 判断为空
- git 怎么看某个commit 修改的代码
- 16周 - 项目一-验证算法-直接插入排序
- 第十六周上机实践项目1 - 验证算法(直接选择排序)
- 测试开发Python培训:模拟登录新浪微博-技术篇 2