- 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)
六、问题及解决方法:
冒泡排序:
当运行此段程序
您可能关注的文档
- (解析适时四驱SUV.doc
- (安全管理制度2006总结和计划.doc
- (解析马航失联的8种可能原因.doc
- (解析骨干教师培训过程中的研究特性.doc
- (安全管理制度汇编综治.doc
- (安全管理工作坚持从细处着手.doc
- (解析高考中的圆锥曲线方程.doc
- (安全管理工作方面有何新的思路.doc
- (安全管理归档及检查表.doc
- (安全管理机制的探索与创新.doc
- 2025年九年级历史上册重难点汇总(统编版)拜占庭帝国和《查士丁尼法典》(课件).pdf
- 2025年浙江省金华市六校联考中考数学模拟试卷+答案解析.pdf
- 2025-2026学年九年级道德与法治上册同步系列(统编版)夯实法治基础(课件).pdf
- 工业机器人应用编程· 中级(汇博)王志强,禹鑫燚,蒋庆斌 著课后习题答案.pdf
- Kubernetes容器部署与应用实战(项目式微课版)杨运强, 吴进, 黄鑫, 主编课后习题答案.pdf
- 国际贸易基础张宗英, 张华, 主编课后习题答案.pdf
- 大数据技术与应用孔华锋课后习题答案.pdf
- 数值分析(基于MATLAB) 周金明、吴小太课后习题答案.pdf
- Visual Basic程序设计基础(双色)陆立波课后习题答案.pdf
- 单片机应用技术(第2版)[C语言版](双色)(含微课)周君芝课后习题答案.pdf
文档评论(0)