教育资源为主的文档平台

当前位置: 查字典文档网> 所有文档分类> > 数学> 数据结构 第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月月考生物试卷

网友关注视频

外研版英语七年级下册module3 unit2第一课时
【部编】人教版语文七年级下册《老山界》优质课教学视频+PPT课件+教案,安徽省
19 爱护鸟类_第一课时(二等奖)(桂美版二年级下册)_T502436
二年级下册数学第一课
8.练习八_第一课时(特等奖)(苏教版三年级上册)_T142692
外研版英语七年级下册module3 unit2第二课时
北师大版八年级物理下册 第六章 常见的光学仪器(二)探究凸透镜成像的规律
北师大版数学四年级下册3.4包装
二年级下册数学第三课 搭一搭⚖⚖
3月2日小学二年级数学下册(数一数)
第五单元 民族艺术的瑰宝_16. 形形色色的民族乐器_第一课时(岭南版六年级上册)_T1406126
沪教版牛津小学英语(深圳用) 四年级下册 Unit 3
外研版英语七年级下册module3 unit1第二课时
北师大版数学 四年级下册 第三单元 第二节 小数点搬家
外研版英语七年级下册module1unit3名词性物主代词讲解
青岛版教材五年级下册第四单元(走进军营——方向与位置)用数对确定位置(一等奖)
苏科版数学 八年级下册 第八章第二节 可能性的大小
第12章 圆锥曲线_12.7 抛物线的标准方程_第一课时(特等奖)(沪教版高二下册)_T274713
沪教版八年级下册数学练习册20.4(2)一次函数的应用2P8
《小学数学二年级下册》第二单元测试题讲解
冀教版小学数学二年级下册第二单元《有余数除法的简单应用》
外研版英语三起6年级下册(14版)Module3 Unit1
第4章 幂函数、指数函数和对数函数(下)_六 指数方程和对数方程_4.7 简单的指数方程_第一课时(沪教版高一下册)_T1566237
苏科版数学八年级下册9.2《中心对称和中心对称图形》
河南省名校课堂七年级下册英语第一课(2020年2月10日)
【部编】人教版语文七年级下册《逢入京使》优质课教学视频+PPT课件+教案,安徽省
沪教版八年级下次数学练习册21.4(2)无理方程P19
精品·同步课程 历史 八年级 上册 第15集 近代科学技术与思想文化
【部编】人教版语文七年级下册《老山界》优质课教学视频+PPT课件+教案,安徽省
人教版二年级下册数学