教育资源为主的文档平台

当前位置: 查字典文档网> 所有文档分类> > 数学> 数据结构 第10章 排序验证型 实验报告

数据结构 第10章 排序验证型 实验报告

上传者:李玉林
|
上传时间:2015-05-10
|
次下载

数据结构 第10章 排序验证型 实验报告

数据结构 实验报告

数据结构

实验报告 第十章

实验名称:排序问题

实验类型:验证性实验

班级:

学号:

姓名:

实验日期:2014年7月5日

1.问题描述

做以下三个验证性实验:

(1)直接插入排序算法验证。

(2)快速排序算法验证。

(3)直接选择排序算法验证。

2.数据结构设计

由于是验证性实验,只需要对数字进行排序,这里使用一维数组即可。

3.算法设计

直接插入算法:

每次从无序表中取出第一个元素,把它插入到有序表的合适位置,使有序表仍然有序。

第一趟比较前两个数,然后把第二个数按大小插入到有序表中; 第二趟把第三个数据与前两个数从前向后扫描,把第三个数按大小插入到有序表中;依次进行下去,进行了n-1趟扫描以后就完成了整个排序过程。

快速排序算法:

1)设置两个变量i、j,排序开始的时候:i=0,j=N-1;

2)以第一个数组元素作为关键数据,赋值给key,即key=A[0];

3)从j开始向前搜索,即由后开始向前搜索(j--),找到第一个小于key的值 A[j],将A[j]赋给A[i];

4)从i开始向后搜索,即由前开始向后搜索(i++),找到第一个大于key的 A[i],将A[i]赋给A[j];

5)重复第3、4步,直到i=j; (3,4步中,没找到符合条件的值,即3中 A[j]不小于key,4中A[i]不大于key的时候改变j、i的值,使得j=j-1,i=i+1, 直至找到为止。找到符合条件的值,进行交换的时候i, j指针位置不变。 另外,i==j这一过程一定正好是i+或j-完成的时候,此时令循环结束)。

数据结构 实验报告

直接选择排序算法:

第一次从R[0]~R[n-1]中选取最小值,与R[0]交换,第二次从R[1]~R[n-1]中选取最小值,与R[1]交换,....,第i次从R[i-1]~R[n-1]中选取最小值,与R[i-1]交换,.....,第n-1次从R[n-2]~R[n-1]中选取最小值,与R[n-2]交换,总共通过n-1次,得到一个按排序码从小到大排列的有序序列。

4.运行、测试与分析

内容需要下载文档才能查看

内容需要下载文档才能查看

5.实验收获及思考

遇到的问题:

数组作为函数参数的使用方法忘记了。

解决办法:

上网查找相关知识后,学会了如何使用数组。

实验的收获:

通过亲自编写三个排序算法的程序,再一次加深了对它们的记忆,同时也复习了数组作为函数参数的使用方法。

数据结构 实验报告

附录:

#include<iostream>

using namespace std;

int a[10]={0,6,5,2,1,4,3,8,7,9};

int b[10]={0,6,5,2,1,4,3,8,7,9};

int c[10]={0,6,5,2,1,4,3,8,7,9};

void printl(int ll[])//输出数组

{

for(int i1=1;i1<10;i1++)

{

cout<<ll[i1]<<" ";

}

cout<<endl;

}

void charu(int l[])//插入排序

{

int i,j;

for(i=1;i<10;i++)

{

if(l[i]<l[i-1])

{

l[0]=l[i];

for(j=i-1;l[0]<l[j];--j)

l[j+1]=l[j];//记录后移

l[j+1]=l[0];//插入到正确位置

}

}

}

void kuaisu(int s[], int l, int r) //快速排序

{

if (l< r)

{

int i = l, j = r, x = s[l];

while (i < j)

{

while(i < j && s[j]>= x) // 从右向左找第一个小于x的数 j--;

if(i < j)

s[i++] = s[j];

while(i < j && s[i]< x) //从左向右找第一个大于等于x //的数

数据结构 实验报告

i++;

if(i < j)

s[j--] = s[i];

}

s[i] = x;

kuaisu(s,l,i-1); // 递归调用

kuaisu(s,i+1,r);

}

}

void xuanze(int s[])//直接选择排序

{

int tem;

for(int i=1;i<=8;i++)//依次用第一个元素和它后面的元素比较 {

for(int j=i+1;j<=9;j++)

{

if(s[j]<s[i])//如果后者大,交换

{

tem=s[j];

s[j]=s[i];

s[i]=tem;

}

}

}

}

int main()

{

cout<<"数组排序前:";printl(a);

charu(a);

cout<<"插入排序后:";printl(a);

cout<<endl;

cout<<"数组排序前:";printl(b);

kuaisu(b,1,9);

cout<<"快速排序后:";printl(b);

cout<<endl;

cout<<"数组排序前:";printl(c);

xuanze(c);

cout<<"选择排序后:";printl(c);

return 0;

}

版权声明:此文档由查字典文档网用户提供,如用于商业用途请与作者联系,查字典文档网保持最终解释权!

下载文档

热门试卷

2016年四川省内江市中考化学试卷
广西钦州市高新区2017届高三11月月考政治试卷
浙江省湖州市2016-2017学年高一上学期期中考试政治试卷
浙江省湖州市2016-2017学年高二上学期期中考试政治试卷
辽宁省铁岭市协作体2017届高三上学期第三次联考政治试卷
广西钦州市钦州港区2016-2017学年高二11月月考政治试卷
广西钦州市钦州港区2017届高三11月月考政治试卷
广西钦州市钦州港区2016-2017学年高一11月月考政治试卷
广西钦州市高新区2016-2017学年高二11月月考政治试卷
广西钦州市高新区2016-2017学年高一11月月考政治试卷
山东省滨州市三校2017届第一学期阶段测试初三英语试题
四川省成都七中2017届高三一诊模拟考试文科综合试卷
2017届普通高等学校招生全国统一考试模拟试题(附答案)
重庆市永川中学高2017级上期12月月考语文试题
江西宜春三中2017届高三第一学期第二次月考文科综合试题
内蒙古赤峰二中2017届高三上学期第三次月考英语试题
2017年六年级(上)数学期末考试卷
2017人教版小学英语三年级上期末笔试题
江苏省常州西藏民族中学2016-2017学年九年级思想品德第一学期第二次阶段测试试卷
重庆市九龙坡区七校2016-2017学年上期八年级素质测查(二)语文学科试题卷
江苏省无锡市钱桥中学2016年12月八年级语文阶段性测试卷
江苏省无锡市钱桥中学2016-2017学年七年级英语12月阶段检测试卷
山东省邹城市第八中学2016-2017学年八年级12月物理第4章试题(无答案)
【人教版】河北省2015-2016学年度九年级上期末语文试题卷(附答案)
四川省简阳市阳安中学2016年12月高二月考英语试卷
四川省成都龙泉中学高三上学期2016年12月月考试题文科综合能力测试
安徽省滁州中学2016—2017学年度第一学期12月月考​高三英语试卷
山东省武城县第二中学2016.12高一年级上学期第二次月考历史试题(必修一第四、五单元)
福建省四地六校联考2016-2017学年上学期第三次月考高三化学试卷
甘肃省武威第二十三中学2016—2017学年度八年级第一学期12月月考生物试卷

网友关注

柴油机IETM研究及系统开发分析
法语背景的非洲留学生汉语语音习得的实验研究
义务教育7~9年级地理课程内容次序研究
基于J2EE的企业应用集成的系统可靠性和安全性研究
机车柴油机凸轮轴型线设计与工艺优化
创新思维在建筑设计中的应用研究
找到最好的教授写作的方法——关于提高学生英语写作能力的几点建议
新课标下的高中物理概念教学策略研究
通讯作者
基于J2EE和Ajax的自动组卷在线考试系统的研究和实现
学位论文-臭氧氧化技术处理感光废水研究(PDF格式可编辑)
洱海沉积物磷形态、释放通量及其生物有效性的研究(可编辑)
论文-格力销售战略
oracle spatial 3d模型存储与可视化研究
元认知策略在壮族高中生听力学习中的应用状况研究-以广西武鸣县壮族高中生为例
基于J2EE架构SSH组合框架研究论文
非英语专业硕士生英语学习策略调查
出版专业中级基础知识笔记
基于J2EE架构的国际普邮系统的设计和实现
任务型教学法在初中英语口语教学中的应用
利用空气污染指数(api)分析我国空气污染的区域时空变化特征
基于J2EE发票管理系统的设计和开发
【精品文献】六路数字抢答器的设计.222
教育管理个人知识及其应用——三位中学校长的个案研究
空气湿度对蓝果忍冬Lonicera+CaeruleaL生长及生理特性影响的初步研究
万能轧机毕业设计
《内蒙古日报通讯》(蒙文版)历史研究
“宇宙”爆炸新说
基于J2EE架构的电信运营计费系统的设计与实现
CA6DL1柴油机的开发研究

网友关注视频

【部编】人教版语文七年级下册《老山界》优质课教学视频+PPT课件+教案,安徽省
冀教版小学数学二年级下册第二单元《有余数除法的竖式计算》
【部编】人教版语文七年级下册《逢入京使》优质课教学视频+PPT课件+教案,安徽省
沪教版牛津小学英语(深圳用)五年级下册 Unit 1
青岛版教材五年级下册第四单元(走进军营——方向与位置)用数对确定位置(一等奖)
第五单元 民族艺术的瑰宝_16. 形形色色的民族乐器_第一课时(岭南版六年级上册)_T1406126
苏科版八年级数学下册7.2《统计图的选用》
二年级下册数学第三课 搭一搭⚖⚖
【部编】人教版语文七年级下册《逢入京使》优质课教学视频+PPT课件+教案,辽宁省
苏教版二年级下册数学《认识东、南、西、北》
外研版英语七年级下册module3 unit2第一课时
冀教版小学数学二年级下册第二单元《有余数除法的整理与复习》
第19课 我喜欢的鸟_第一课时(二等奖)(人美杨永善版二年级下册)_T644386
【部编】人教版语文七年级下册《泊秦淮》优质课教学视频+PPT课件+教案,湖北省
冀教版小学英语四年级下册Lesson2授课视频
沪教版牛津小学英语(深圳用) 四年级下册 Unit 3
北师大版数学四年级下册3.4包装
苏科版数学八年级下册9.2《中心对称和中心对称图形》
沪教版八年级下次数学练习册21.4(2)无理方程P19
第五单元 民族艺术的瑰宝_15. 多姿多彩的民族服饰_第二课时(市一等奖)(岭南版六年级上册)_T129830
外研版英语三起6年级下册(14版)Module3 Unit1
飞翔英语—冀教版(三起)英语三年级下册Lesson 2 Cats and Dogs
二次函数求实际问题中的最值_第一课时(特等奖)(冀教版九年级下册)_T144339
七年级英语下册 上海牛津版 Unit9
苏科版数学 八年级下册 第八章第二节 可能性的大小
沪教版八年级下册数学练习册21.4(1)无理方程P18
苏科版数学七年级下册7.2《探索平行线的性质》
冀教版英语四年级下册第二课
化学九年级下册全册同步 人教版 第25集 生活中常见的盐(二)
北师大版数学 四年级下册 第三单元 第二节 小数点搬家