数据结构 第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月月考生物试卷
网友关注
- 大手拉小手运动会
- 春季儿童咳嗽高发 止咳应以
- 安全之痛,幼儿事故何时才能休?
- 董进宇:一个教育经验丰富的老教师,给家长的5点忠告。
- 明白这12条忠告--孩子想不优秀都难
- 两岁宝宝的教育
- 大手拉小手 清洁美丽幼儿园倡议书
- 大班社会教学活动《美丽的家乡》
- 中国大陆性价比最高少儿教育金储备计划隆重市01
- 谁为留守学生导航
- 家长必读:过度教育容易导致孩子学习障碍
- 两个月宝宝大便次数少怎么办
- 新乡儿童摄影漂亮宝贝公司概况
- 教育
- 注意力训练1
- 冉云飞:我为何反对给孩子灌输孝道
- 在Oracle下开发JAVA程序的问题解答
- 董进宇:这样教,孩子不优秀都难
- 让孩子学习上瘾的方法,不信试试看!
- 董进宇:一个在美国的中国妈妈分享育儿绝招 值得每个妈妈学习
- 浅谈写生对儿童的影响
- 决定孩子一生的不是学习成绩,而是健全的人格修养!
- 博瑞智家庭教育一位资深老师说给家长的七句话!
- 培养孩子耐性的有效三秘诀 (2)
- 如何辨别出哪些水果是催熟的,少给孩子吃!
- 夏天宝宝长痱子怎么办
- 小熊仔计算
- 父母与亲子发生冲突的最佳办法?
- 董进宇:中国人带孩子,不该这么难
- 听知觉训练材料
网友关注视频
- 外研版英语七年级下册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课件+教案,安徽省
- 人教版二年级下册数学
精品推荐
- 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
- 网吧管理