数据结构 第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集 生活中常见的盐(二)
- 北师大版数学 四年级下册 第三单元 第二节 小数点搬家
精品推荐
- 2016-2017学年高一语文人教版必修一+模块学业水平检测试题(含答案)
- 广西钦州市高新区2017届高三11月月考政治试卷
- 浙江省湖州市2016-2017学年高一上学期期中考试政治试卷
- 浙江省湖州市2016-2017学年高二上学期期中考试政治试卷
- 辽宁省铁岭市协作体2017届高三上学期第三次联考政治试卷
- 广西钦州市钦州港区2016-2017学年高二11月月考政治试卷
- 广西钦州市钦州港区2017届高三11月月考政治试卷
- 广西钦州市钦州港区2016-2017学年高一11月月考政治试卷
- 广西钦州市高新区2016-2017学年高二11月月考政治试卷
- 广西钦州市高新区2016-2017学年高一11月月考政治试卷
分类导航
- 互联网
- 电脑基础知识
- 计算机软件及应用
- 计算机硬件及网络
- 计算机应用/办公自动化
- .NET
- 数据结构与算法
- Java
- SEO
- C/C++资料
- linux/Unix相关
- 手机开发
- UML理论/建模
- 并行计算/云计算
- 嵌入式开发
- windows相关
- 软件工程
- 管理信息系统
- 开发文档
- 图形图像
- 网络与通信
- 网络信息安全
- 电子支付
- Labview
- matlab
- 网络资源
- Python
- Delphi/Perl
- 评测
- Flash/Flex
- CSS/Script
- 计算机原理
- PHP资料
- 数据挖掘与模式识别
- Web服务
- 数据库
- Visual Basic
- 电子商务
- 服务器
- 搜索引擎优化
- 存储
- 架构
- 行业软件
- 人工智能
- 计算机辅助设计
- 多媒体
- 软件测试
- 计算机硬件与维护
- 网站策划/UE
- 网页设计/UI
- 网吧管理