- 20
- 0
- 约 8页
- 2017-01-12 发布于重庆
- 举报
实验报告-各种排序方法及其实现.
计算机学院实验报告专用纸
实验室:网络实验室 机号:网38 实验日期:2010年6月25日
姓名 XXX 班级 课程名称 数据结构 任课教师 实验项目名称 各种排序方法及其实现 指导教师 实验组别 X 同组者 无 教师评语及成绩:
实验成绩: 教师签字: (请按照实验报告的有关要求书写。一般必须包括:1、实验目的;2、实验内容;3、实验步骤与方法;4、实验数据与程序清单;5、出现的问题与解决方法;6、实验结果、结果分析与体会等内容)
1、实验目的(1)(2)()实验(1)(2)。实验(1)编写排序函数(2)设计一个测试主函数,实现对排序算法的测试。
(3)分析程序的运行结果。实验#includestdio.h
#includestdlib.h
#define Max 100 //假设文件长度
typedef struct{ //定义记录类型
int key; //关键字项
}RecType;
typedef RecType SeqList[Max+1]; //SeqList为顺序表,表中第0个元素作为哨兵
int n; //顺序表实际的长度
//==========直接插入排序法======
void InsertSort(SeqList R)
{ //对顺序表R中的记录R[1‥n]按递增序进行插入排序
int i,j;
for(i=2;i=n;i++) //依次插入R[2],……,R[n]
if(R[i].keyR[i-1].key){ //若R[i].key大于等于有序区中所有的keys,则R[i]留在原位
R[0]=R[i];j=i-1; //R[0]是R[i]的副本
do
{ //从右向左在有序区R[1‥i-1]中查找R[i] 的位置
R[j+1]=R[j]; //将关键字大于R[i].key的记录后移
j--;
}
while(R[0].keyR[j].key); //当R[i].key≥R[j].key 是终止
R[j+1]=R[0]; //R[i]插入到正确的位置上
}//endif
}
//==========冒泡排序=======
typedef enum {FALSE,TRUE} Boolean; //FALSE为0,TRUE为1
void BubbleSort(SeqList R) { //自下向上扫描对R做冒泡排序
int i,j; Boolean exchange; //交换标志
for(i=1;in;i++) { //最多做n-1趟排序
exchange=FALSE; //本趟排序开始前,交换标志应为假
for(j=n-1;j=i;j--) //对当前无序区R[i‥n] 自下向上扫描
if(R[j+1].keyR[j].key){ //两两比较,满足条件交换记录
R[0]=R[j+1]; //R[0]不是哨兵,仅做暂存单元
R[j+1]=R[j];
R[j]=R[0];
exchange=TRUE; //发生了交换,故将交换标志置为真
}
if(! exchange) //本趟排序未发生交换,提前终止算法
return;
}// endfor(为循环)
} 计算机学院实验报告附页
姓名 XXX 班级 实验名称 各种排序方法及其实现 //========一次划分函数=====
int Partition(SeqList R,int i,int j)
{ // 对R[i‥j]做一次划分,并返回基准记录的位置
RecType pivot=R[i]; //用第一个记录作为基准
while(ij) { //从区间两端交替向中间扫描,直到i=j
while(ij R[j].key=pivot.key) //基准记录pivot相当与在位置i上
j--; //从右向左扫描,查找第一个关键字小于pi
原创力文档

文档评论(0)