数据结构试验报告 - 各种内排序算法的实现及性能比较
实 验 报 告
( 2010 / 2011 学年 第 2 学期)?
???
课程名称 数据结构——使用C++语言描述 实验名称 各种内排序算法的实现及性能比较
实验时间 2011 年 5 月 27 日
指导单位 计算机科学与技术系 指导教师
学生姓名 学院(系)
班级学号 专 业
实验名称 实验类型
设计 各种内排序算法的实现及性能比较 指导老师 实验学时 4 实验时间 2011.5.27 一.实验目的和要求
内容:
验证教材的各种内排序算法。分析各种排序算法的时间复杂度。 要求:
使用随机数产生器产生大数据集合,运行上述各种排序算法,使用系统时钟测量各算法所需的实际时间,并进行比较。
二.实验环境(实验设备)
Visual C++6.0
三.实验原理及内容
//selectsort.h
#include
void SelectSort(T A[], int n) {
int small;
for (int i=0; i
#include
void InsertSort(T A[], int n) {
for(int i=1; i int j=i; T temp=A[i]; while(j>0&&temp Bubblesort.h #include void BubbleSort(T A[], int n) { int i,j,last; i=n-1; while(i>0){ last=0; for(j=0;jQuicksort.h #include int *a; //用数组保存待排序的子序列的上、下界 int top=0,right,left,j; //left和right为待排序 a=new int[n]; if(a==NULL) return; a[top++]=0; a[top++]=n-1; //以初始序列为待排序序列开始改进的快速排序 //lc for(j=0;a[j]!=NULL;j++) //循环到数组元素为空 { left=a[j++]; right=a[j]; //每次按序从数组中取出两个元素作为待排序序列的上、下界 if(left>right) Swap(left,right); //如果下界大于上界,交换上、下界 if(right-left<15) InsertSortExt(A,left,right); //若元素较少调用插入排序 else { a[top++]=left; a[top++]=QuickSort(A,left,right)-1; a[top++]=a[top-2]+2; a[top++]=right; //否则将低、高端序列上、下界依次保存到数组中 } } } template int QuickSort(T A[],int left,int right) //用于改进的快速排序的原始快速排序方法 { int i,j; if(left return 0; } template void InsertSortExt(T A[],int left,int right)//用于快速排序的直接插入排序方法 { for(int i=left+1; i Mergesort.h #include template void Merge(T A[],int i1,int j1,int i2,int j2) { // i1,j1是子序列1的下、上界,i1,j2是子序列2的下、上界 T *Temp=new T[j2-i1+1]; //分配能存放两个子序列的临时数组 int i=i1,j=i2,k=0; //i,j是两个子序列的游动指针,k是Temp的游动指针 while(i<=j1&&j<=j2) if(A[i]<=A[j])Temp[k++]=A[i++]; else Temp[k++]=A[j++]; while(i<=j1)Temp[k++]=A[i++]; while(j<=j2)Temp[k++]=A[j++]; for(i=0;i delete [] Temp; } //合并排序的C++程序 template void MergeSort(T A[], int n) { int i1,j1,i2,j2; //i1,j1是子序列1的下、上界,i2,j2是子序列2的下、上界 int size=1; //子序列中元素个数,初始化为1。 while(size Heapsort.h #include void AdjustDown(T A[], int r, int j) { int child=2*r+1; T temp=A[r];
相关推荐:
- [学前教育]MC9S12XS256RMV1 xs128芯片手册4
- [学前教育]安东尼语录经典语录
- [学前教育]e级gps控制测量技术设计书
- [学前教育]苏教版2022-2022学年八年级下学期期末
- [学前教育]装修公司推广 营销
- [学前教育]家政服务合同(完整版)
- [学前教育]湖北省2016届高三联考语文试题
- [学前教育]爱立信无涯学习系统LTE题库1-LTE基础知
- [学前教育]揭秘大众柴油车作弊软件原理
- [学前教育]人才流失原因及对策分析
- [学前教育]房屋建筑施工工程劳务分包合同
- [学前教育]国际贸易实务试卷A卷09.6
- [学前教育]校园废品回收活动计划方案书范文格
- [学前教育]电大成本会计试题及答案
- [学前教育]大学物理实验 华南理工出版社 绪论答案
- [学前教育]爱丁堡产后抑郁量表
- [学前教育]液压冲击的危害、产生原因与防止方法(
- [学前教育]学生工作总结高一学生期中考试总结_020
- [学前教育]人民医院医疗废物管理规章制度大全
- [学前教育]阳光维生素的巨大抗癌潜能阅读题答案.d
- 马云在云锋基金江苏论坛闭幕式的发言
- 试论小学体育教育中的心理健康教育-教
- 语文A版一年级下册《语文乐园一》教学
- 2021四川大学物理化学考研真题经验参考
- [人教A版]2015-2016学年高中数学 第二
- 终端网点销售返利协议书
- 江苏省2015年眼科学主治医师青光眼考试
- 2017年部编人教版八年级语文上册教案
- 十一中学七年级英语上册Unit7Howmuchar
- 以赛促教的创新性实验教学机制建设实践
- 平凉市崆峒区2015七年级下生物期末试题
- 琶洲(地块五)A、B塔楼1、2#塔吊基础
- 一级医院工作制度与人员岗位职责
- 2018北京西城区高三二模理科数学试题及
- 炒股密码线技术 - 图文
- 职高学生生涯发展辅导教案
- 语文人教版四年级上册8 世界地图引出的
- 最新最新人教版二年级上册全册数学教案
- 2017高考英语全国2卷精彩试题(有问题
- 普通心理学笔记




