算法排序问题实验报告_第1页
算法排序问题实验报告_第2页
算法排序问题实验报告_第3页
算法排序问题实验报告_第4页
已阅读5页,还剩6页未读 继续免费阅读

付费下载

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、.排序问题求解实验报告一、算法的基本思想1、直接插入排序算法思想直接插入排序的基本思想是将一个记录插入到已排好序的序列中,从而得到一个新的,记录数增 1 的有序序列。直接插入排序算法的伪代码称为InsertionSort ,它的参数是一个数组A1.n ,包含了n个待排序的数。用伪代码表示直接插入排序算法如下:InsertionSort (A)for i 2 to ndo key Ai /key表示待插入数/Insert Ai into the sorted sequence A1.i-1j i-1while j>0 and Aj>keydo Aj+1 Ajj j-1Aj+1 key

2、2、快速排序算法思想快速排序算法的基本思想是,通过一趟排序将待排序序列分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可对这两部分记录继续进行排序,以达到整个序列有序。假设待排序序列为数组A1.n ,首先选取第一个数A0 ,作为枢轴( pivot ),然后按照下述原则重新排列其余数:将所有比A0 大的数都排在它的位置之前,将所有比A0小的数都排在它的位置之后,由此以A0 最后所在的位置i 作为分界线,将数组A1.n分成两个子数组 A1.i-1 和 Ai+1.n 。这个过程称作一趟快速排序。通过递归调用快速排序,对子数组 A1.i-1 和 Ai+1.n 排序。一趟快速排序

3、算法的伪代码称为Partition, 它的参数是一个数组A1.n 和两个指针low 、high,设枢轴为 pivotkey ,则首先从 high 所指位置起向前搜索, 找到第一个小于 pivotkey 的数,并将其移到低端, 然后从 low 所指位置起向后搜索, 找到第一个大于 pivotkey 的数,并将其移到高端,重复这两步直至low=high 。最后,将枢轴移到正确的位置上。用伪代码表示一趟快速排序算法如下:Partition ( A, low, high)A0 Alow/用数组的第一个记录做枢轴记录privotkey Alow/枢轴记录关键字while low<high / 从表

4、的两端交替地向中间扫描while low<high && Ahigh>=privotkey do high high-1Alow Ahigh / 将比枢轴记录小的记录移到低端while low<high && Alow<=pivotkey) do low low+1Ahigh Alow / 将比枢轴记录大的记录移到高端Alow A0 / 枢轴记录到位return low / 返回枢轴位置二、算法的理论分析.1. 直接插入排序算法理论分析从空间来看,直接插入排序只需要一个数的辅助空间;从时间来看,直接插入排序的基本操作为:比较两个关键字的大

5、小和移动记录。先分析一趟直接插入排序的情况。伪代码InsertionSort 中 while循环的次数取决于待插入的数与前i-1 个数之间的关系。若Ai<A0, 则在 while循环中,待插入数需与有序数组A1.i-1 中 i-1 个数进行比较,并将Ai-1 中 i-1 个数后移。则在整个排序过程(进行n-1趟插入排序)中,当待排序数组中数按非递减有序排列时,则需进行数间比较次数达最小值n-1,数不需要移动;反之,当待排序数组中数按非递增有序排列时,总的比较次数达最大值(n+2)(n-1)/2 ,数移动的次数也达到最大值 (n+4)(n-1)/2 。若待排序数组是随机的, 即待排序数组中

6、的数可能出现的各种排序的概率相同,则我们可取上述最小值和最大值的平均值,作为直接插入排序时所需进行数间的比较次数和数的移动次数,约为 n2/4 。因此直接插入排序算法,在最佳情况下的时间复杂度是O(n) ,在最坏情况下的时间复杂度为 O(n2) 。2. 快速排序算法理论分析下面我们来分析快速排序的平均时间性能。假设 T(n) 为对 n 个记录 A1.n 进行快速排序所需时间,则由算法QuickSort 可见:其中, Tpass(n)为对 n 个记录进行一趟快速排序Partition ( A,1,n )所需的时间,从一趟快速排序算法可见, 其和记录数n 成正比,可以用 cn 表示( c 为某个常

7、数);T(k-1) 和 T(n-k )分别为对 A1.k-1和 Ak+1.n 中记录进行快速排序QuickSort ( A,1,k-1 )和QuickSort ( A,k+1,n )所需时间。假设待排序列中记录是随机排列的,则在一趟排序之后,k 取 1 至 n 之间任何一值的概率相同,快速排序所需时间的平均值则为Tavg(n)=knInn ,其中 n 为待排序序列中记录的个数,k 为某个常数。通常,快速排序被认为是,在所有同数量级(O(nlogn) )的排序方法中,其平均性能最好。但是, 若初始记录序列按关键字有序或基本有序时,快速排序将蜕化为起泡排序, 其时间复杂度为 O(n2) 。三、试验

8、分析1、试验环境WIN 32 系统, VC6.02、 程序的执行1)由函数 datagenetare()生成 20000个在区间 1,100000 上的随机整数, 并将随机整数保存到数组 num ,接着调用函数WriteFile() 将这些数输出到外部文件data.txt 中。2)调用函数 ReadFile() 从 data.txt 中读取数据,并将其保存到数组num1 中。接着对数组num1 进行直接插入排序,并计算和记录其运行时间。最后,调用函数WriteFile() 将直接插入排序的结果写入resultsIS.txt ,并记录运行时间为TimeIS 。3)调用函数 ReadFile()

9、从 data.txt 中读取数据,并将其保存到数组num2 中。接着对数组num2 进行快速排序,并计算和记录其运行时间。最后,调用函数WriteFile() 将快速排序的结果写入 resultsQS.txt,并记录运行时间为 TimeQS 。3、试验数据当 N=20000 时:.当 N=30000 时:当 N=40000 时:.当 N=50000 时:当 N=60000 时:.当 N=70000 时:当 N=80000 时:.4、实验结果分析20000300004000050000600007000080000插入排序 0.3250.7191.3972.1993.054.5715.46快速排

10、序 0.0030.0050.0080.010.0120.0110.013做出折线统计图.四、试验心得通过本次试验首先对在C+ 下的文件操作有了一定的深入认识,对于快速排序和插入排序的时间有了相当清晰且一目了然的认识,并且从原理上明白了快速排序的快的原因,对各种排序算法的优劣性有了全局的认识!五、实验代码#include <iostream>#include <ctime>#include <cstdlib>#include <fstream>#include <string>using namespace std;const int

11、NumS = 80000;void datagenetare(int num,int n); / 产生随机数,保存到数组numvoid WriteFile(int num,char name,int n); /输出数组num 到 data.txt 文件void ReadFile(int num,char name);/读取名为name 文件中的数据,保存到数组numvoid QuickSort(int arr, int n);/将数组 arr 中数据快速排序void InsertionSort(int arr,int n);/将数组 arr 中数据直接插入排序int main()int *nu

12、m=(int *)malloc(sizeof(int)*NumS);int *num1=(int *)malloc(sizeof(int)*NumS);int *num2=(int *)malloc(sizeof(int)*NumS);clock_t start_time1,end_time1,start_time2,end_time2;double timeQS=0,timeIS=0;cout<<"Create "<<NumS<<" random numbers from 1 to 100000"<<en

13、dl; datagenetare(num,NumS); / 产生随机数,保存到数组 num WriteFile(num,"data.txt",NumS); / 输出数组到 data.txt 文件cout.precision(6); / 设置浮点数的显示精度cout.setf(ios_base:showpoint); / 输出末尾的./直接插入排序的分析ReadFile(num1,"data.txt");/ 读取 data.txt 中的数据,保存到数组num1cout<<"nInsertionSort Start .n"st

14、art_time1=clock(); / 开始计时InsertionSort(num1,NumS); / 直接插入排序数组num1 中的数据end_time1=clock(); / 结束计时timeIS=(double)(end_time1-start_time1)/CLOCKS_PER_SEC;cout<<"The Time-comsuption in InsertionSort is "<<timeIS<<" seconds!nn" /输出运行时间WriteFile(num1,"resultsIS.txt

15、",NumS); / 排序后的数据输出到 resultQS.txt /输出运行时间 timeIS 到 resultsIS.txtofstream ocout;ocout.open("resultsIS.txt",ios:app);if(ocout.good() / 打开 resultsIS.txtocout<<"nThe Time-comsuption in InsertionSort is "<<timeIS<<" secondsn" ocout.close();elsecout<

16、<"nCan not open resultsIS.txt!n"exit(1); / 异常退出/快速排序的分析ReadFile(num2,"data.txt"); / 读取 data.txt 中的数据,保存到数组num2cout<<"QuickSort Start .n"start_time2=clock(); / 开始计时QuickSort(num2,NumS); / 快速排序数组num 中的数据end_time2=clock(); / 结束计时timeQS=(double)(end_time2-start_tim

17、e2)/CLOCKS_PER_SEC;cout<<"The Time-comsuption in QuickSort is "<<timeQS<<" seconds:n" / 输出运行时间 WriteFile(num2,"resultsQS.txt",NumS); / 排序后的数据输出到 resultQS.txt /输出运行时间 timeQS 到 resultsQS.txtocout.open("resultsQS.txt",ios:app);if(ocout.good() /

18、打开 resultsIS.txtocout<<"nThe Time-comsuption in QuickSort is "<<timeQS<<" secondsn" ocout.close();elsecout<<"nCan not open resultsQS.txt!n"exit(1); / 异常退出.return 0;void datagenetare(int *num,int n)int i;srand(unsigned)time(0); /srand() 种子发生器函数,还有

19、rand()随机数生成器函数for(i=0;i<n;i+) /产生个到之间的随机数numi=rand()%9999+1;printf("n");/将数组中的数据输出到文件void WriteFile(int *num,char name,int n)ofstream ocout;ocout.open(name,ios:trunc);int i=0;if(ocout.fail()exit(1); / 打开文件失败,退出for(;i<n;i+)ocout<<numi<<" "if(i+1)%40=0|i=n-1) /每输出

20、 40 个数,换一行ocout<<"n"ocout.close();/将文件中的数据输入到数组void ReadFile(int *num,char name)string strLine;int i=0;char achLine300;const char* pchTok;ifstream icin;icin.open(name,ios:in); / 打开名为name 的文件while(icin.good()int i = 0;while(getline(icin,strLine)strLine.copy(achLine,strLine.size(),0);achLinestrLine.size()='0'/ 每行中的元素以空格为标识断开转换为int 类型后存入数组pchTok = strtok(achLine, " ");.while(pchTok != NULL)numi = atoi(pchTok);i+;pchTok = strtok(NULL, " ");icin.c

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论