- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实现冒泡排序、直接入排序和直接选择排序的算法
实验报告
一、实验题目:冒泡排序、直接插入排序和直接选择排序的算法。
二、实验环境:window7、mytc、计算机一台
三、实验目的:通过编程熟练掌握实现冒泡排序、直接插入排序和直接选择排序的算法。
四、实验内容:(1)输入数据运算字符。
首先输入冒泡排序的运算程序:
#define N 4
void bustor(int x[], int n)
{
int i,j,m,k;
for(i=1;i=n-1;i++) /*n个数进行n-1趟排序*/
{
k=1; /*各趟开始假定本趟不会发生数据交换*/
for(j=1;j=n-1;j++) /*第i趟比较n-i次*/
if(x[j]x[j+1])
{
m=x[j];
x[j]=x[j+1]; /*相邻两数交换*/
x[j+1]=m;
k=0; /*本趟发生了数据交换*/
}
if(k==1)break;
}
}
之后运行主程序
main() /*程序由此开始*/
{
int a[N+1],i;
for(i=1;i=N;i++)
scanf(%d,a[i]); /*输入N个数*/
bustor(a,N); /*调用冒泡排序函数*/
for(i=1;i=N;i++)
printf(%4d,a[i]); /*输出排序后的序列*/
} /*数据到此结束*/
查看程序是否正常运行。
输入直接插入#define N 7
void sis(int r[], int n)
{
int i,j;
for(i=2;i=n;i++) /*从第2个数开始逐个插入*/
{
r[0]=r[i]; /*把待插数保存到r[0]中*/
j=i-1;
while(r[0]r[j]) /*待插数小于前面数时,做下面工作*/
{
r[j+1]=r[j]; /*前面数据后移1位*/
j--;
}
r[j+1]=r[0]; /*找到了插入位置,第i个数插入完毕*/
}
}
之后运行主程序
main() /*程序由此开始*/
{
int a[N+1],i;
for(i=1;i=N;i++)
scanf(%d,a[i]); /*输入n个数*/
sis(a,N); /*输入n个数*/
for(i=1;i=N;i++)
printf(%4d,a[i]); /*程序到此结束*/
}
查看程序是否正常运行。
输入直接选择#define N 6
void bustor(int x[], int n)
{
int i,j,m,k;
for(i=1;i=n-1;i++) /*n个数进行n-1趟排序*/
{
k=i; /*第i趟开始假设第i个数最小*/
for(j=i+1;j=n;j++) /*从第i+1个数到n个数找最小数的下标k*/
if(x[j]x[k])
k=j;
if(k!=i) /*若最小数不在第i个位置,则交换*/
{
m=x[i];
x[i]=x[k];
x[k]=m;
}
}
}
/*返回main中sestor(a,N);的下一句*/
之后运行主程序
main() /*程序由此开始*/
{
int a[N+1],i;
for(i=1;i=N;i++)
scanf(%d,a[i]); /*输入N个数*/
bustor(a,N); /*调用排序函数*/
for(i=1;i=N;i++)
printf(%4d,a[i]); /*输出排序结果*/
printf(\n); /*程序到此结束*/
}
查看程序是否正常运行。
五、程序验证:
冒泡排序调试分析
运行情况如下:
9 5 2 4 (输入)
2 4 5 9 (输出)
直接插入排序调试分析;
(1)运行结果如下:
5 8 9 4 3 6 5 (输入)
3 4 5 5 6 8 9 (输出)
直接选择排序调试分析;
(1)运行结果如下:
5 8 2 4 6 1 (输入)
1 2 4 5 6 8 (输出)
2 5 8 9 4 (输入)
2 4 5 8 9 (输出)
冒泡排序:
其时间复杂度为O(n2)
其空间复杂度为O(1)
直接插入排序:
其时间复杂度为O(n)
其空间复杂度为O(1)
直接选择排序:
其时间复杂度为O(n2)
其空间复杂度为O(1)
六、问题及解决方法:
冒泡排序:
当运行此段程序
您可能关注的文档
- 安全知识竞赛复习题Microsoft Word 文档.doc
- 安化县食品安全诚信系建设示范单位申请表.doc
- 安全生产责任制和安生产规章制度史上最全的 3.doc
- 安全监理实施规程(月25日报审稿)Microsoft Word 文档.doc
- 安全生产许可证与三人员安全生产考核合格证.doc
- 安全生产法及相关法知识 基础班(全)第3章讲义1.doc
- 安全资料台帐之四~部(分项)工程安全技术交底---有用.doc
- 安县上半年公开招聘业单位工作人员的公告.doc
- 安卓4.0购机全面导(推荐几款智能机).doc
- 安卓手机-使用分区现虚拟内存 来增加RAM和ROM.doc
- 实用(中学)心理学时作业及答案第1次平时作业(第1—3章).doc
- 实施科研课题拉动策促进教师专业化发展的案例研究.doc
- 实行生产许可证制度理的产品有关产业政策的规定.doc
- 实证研究:两经营型式下的公共体育场馆管理和运营分析(以福建福州为例).doc
- 实现“中国梦”----------建党92周年.doc
- 实用新型-带蓄电池电功能的太阳能控制盒.doc
- 实用小型信息系统的发—在面向对象程序设计思想指导下用vfp开发图书管理系统.doc
- 实践成“硬指标” “双师型”教师如何锻造.doc
- 实验 六 Strus2和Hibernate整合基础.doc
- 实验7(Excel据清单管理及函数综合应用).docx
文档评论(0)