




已阅读5页,还剩5页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
算法分析实验报告实验一 分治策略排序实验目的1)以排序问题为例,掌握分治法的基本设计策略;2)熟练掌握合并排序算法的实现;3)熟练掌握快速排序算法的实现;4) 理解常见的算法经验分析方法。实验环境计算机、C语言程序设计环境、VC+6.0实验步骤算法的基本描述:1、 合并排序的基本思想描述:首先将序列分为两部分,分到每组只有两个元素,然后对每一部分进行循环递归地合并排序,然后逐个将结果进行合并。2、 快速排序的基本思想描述:将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,最后达到排序效果。要求:编写一个函数data-generate,生成2000个在区间1,10000上的随机整数,并将这些数输出到外部文件data.txt中。这些数作为本算法实验的输入数据。程序流程图:合并排序原理图快速排序流程图1.生成2000个随机整数的程序:#include#include#includeint main()FILE *fpt;fpt = fopen(D:/data.txt,w);srand(time(0);for(int i=0;i2000;i+)fprintf(fpt,%3dt,rand()%10000+1);return 0;fclose(fpt);并生成data.txt文件。2.读取data.txt文件,并排序。实现合并排序算法输入:待排数据文件data.txt;输出:有序数据文件resultsMS.txt合并排序算法:#include #include #include void mergesort(int a,int n); void merge(int a,int b,int i,int c,int j); int main() int a2000; int i=0,j; FILE *fpt; fpt=fopen(D:data.txt,r);if(fpt=fopen(D:data.txt,r)=NULL)printf(n error!);exit(0);while (fscanf(fpt,%d,&ai)!=EOF)i+; mergesort(a,2000); fpt = fopen(D:/resultMS.txt,w); srand(time(0); for(j=0;j2000;j+) printf(%d ,aj); fprintf(fpt,%3dt,aj); fclose(fpt); return 0; void mergesort(int a,int n) if(n=1) return; int i,j; int *b; int *c; b=(int *)malloc(sizeof(int)*(n/2); c=(int *)malloc(sizeof(int)*(n-n/2); for(i=0;in/2;i+) bi=ai; for(j=0;jn-n/2;j+) cj=aj+n/2; mergesort(b,(n/2); mergesort(c,(n-n/2); merge(a,b,(n/2),c,(n-n/2); void merge(int a,int b,int x,int c,int y) int i=0; int j=0; int k=0; while(ix)&(jy) if(bi=cj) ak=bi; i+; else ak=cj; j+; k+; int l; if(i=x) for(l=j;ly;l+) ak=cl; k+; else for(l=i;lx;l+) ak=bl; k+; 运行结果为:并且在D盘内生成resultMS.txt文件。resultMS.txt内的数即为随机生成的数的排序。3.实现QuickSort 算法。输入:待排数据文件data.txt;输出:有序数据文件resultsQS.txt程序:#include #include #include int partions(int l,int low,int high)int prvotkey=llow;l0=llow;while (lowhigh) while (low=prvotkey) -high; llow=lhigh; while (lowhigh&llow=prvotkey) +low; lhigh=llow;llow=l0;return low;void qsort(int l,int low,int high)int prvotloc;if(lowhigh) prvotloc=partions(l,low,high); /第排序结作枢轴 qsort(l,low,prvotloc-1); /递归调用排序 由low prvotloc-1 qsort(l,prvotloc+1,high); /递归调用排序 由 prvotloc+1 highvoid quicksort(int l,int n)qsort(l,1,n); /第作枢轴 第排第nvoid main()int a2000;int i=0;FILE *fpt; fpt=fopen(D:data.txt,r);if(fpt=fopen(D:data.txt,r)=NULL)printf(n error);exit(0);while (fscanf(fpt,%d,&ai)!=EOF)i+;quicksort(a,2000);fpt=fopen(D:resultsQS.txt,w);srand(time(0);for(int j=1;j2000;j+)printf(%3dt,aj);fprintf(fpt,%3dt,aj);fclose(fpt);运行的结果:生成resultsQS文件程序运行的时间:TimeMS的运行时间为0.0000msTimeQS的运行时间为:产生的原因:可能是计算机运行速度太快,两者运行时间没有太大的差距,所以程序运行的时间约为0.实验分析:从理论上看,快速排序最好情形的时间复杂度为O(NlogN),最坏的情形为O(N*N),平均时间复杂度O(NlogN)。归并排序最好情形的时间复杂度为O(NlogN),最坏的情形为O(NlogN),平均时间复杂度O(NlogN)。因此,可以看出,快速排序算法较之合并排序而言更有优势,尽管保持在
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 灯具店转让合同范本
- 检验工作心得体会和感悟(汇编10篇)
- 金融科技支付服务消费金融模式用户消费方式提升创新性
- 2025年高考日语试卷及答案
- 需求工程试题及答案
- 2025年康复解剖大题题库及答案
- 汤沟酒厂招聘考试试题及答案
- 2025年山西特岗教师招聘考试试题(附答案)
- CN222961012U 一种欧式双梁桥式起重机 (河南力富特起重运输机械有限公司)
- 2025年船舶测速题库及答案
- 压力疏导培训课件
- 肠造口回纳手术
- 篮球场改造工程施工组织设计方案
- 业务知识演讲稿:“三重一大”事项集体决策制度规范运用的思考
- 起搏器植入围手术期护理
- 《数学(第8版 上册)》 课件 第1章 运算与方程
- 中学生天文知识竞赛考试题库500题(含答案)
- 生活妆课件教学课件
- 儿童英语小故事100篇englishforchildren
- 高中数学集合练习题160题-包含所有题型-附答案
- 人教部编版七年级语文上册《秋天的怀念》示范课教学课件
评论
0/150
提交评论