实验报告-各种排序方法及其实现..docVIP

  • 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)

1亿VIP精品文档

相关文档