C++中如何使用蛮力法求解冒泡排序
发表于:2024-12-12 作者:千家信息网编辑
千家信息网最后更新 2024年12月12日,本篇内容介绍了"C++中如何使用蛮力法求解冒泡排序"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!算法
千家信息网最后更新 2024年12月12日C++中如何使用蛮力法求解冒泡排序
本篇内容介绍了"C++中如何使用蛮力法求解冒泡排序"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
算法思想:
比较列表中相邻的元素,如果是逆序的话,就交换他们的位置。重复多次之后,最大的元素就排到了最后一个位置。第二遍操作将第二个元素排到了倒数第二个位置上,这样一直依次比较下去,直到 n-1 遍之后,就排好了整个列表。
下面是我的代码实现:C++
#includeusing namespace std;int main(){ int i,j,temp,N; cin>>N; int *Arr=new int[N]; for(i=0;i>Arr[i]; for(i=0;ifor(j=0;jif(Arr[j]>Arr[j+1])//如果逆序,就交换 { temp=Arr[j]; Arr[j]=Arr[j+1]; Arr[j+1]=temp; } } } for(i=0;i" "; return 0;}
算法分析:输入的规模完全由N决定,基本操作是比较:Arr[j]>Arr[j+1],时间复杂度C(n)=Θ(n2).
但是键的交换次数是取决于特定的输入,最差的情况是与我们要求的排序相反的,这时候键的交换次数=键的比较次数=Θ(n2).
但是在有的输入情况下,如果在对列表比较一遍之后,没有交换元素的位置,那么这个列表已经有序了,我们就可以停止该算法了。具体改进版本如下:
#includeusing namespace std;int main(){ int i,j,temp,N; bool change=false; cin>>N; int *Arr=new int[N]; for(i=0;i>Arr[i]; for(i=0;ifalse; for(j=0;jif(Arr[j]>Arr[j+1])//如果逆序,就交换 { temp=Arr[j]; Arr[j]=Arr[j+1]; Arr[j+1]=temp; change=true; } } if(!change)//没有发生交换,则不用继续比较了。 { break; } } for(i=0;i" "; return 0;}
但是在最差情况下,时间复杂度还是Θ(n2).
"C++中如何使用蛮力法求解冒泡排序"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!
元素
情况
排序
位置
次数
算法
逆序
输入
C++
复杂
最差
内容
复杂度
时间
是在
更多
知识
实用
最大
有序
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
客户服务器体系结构的数据库
洞天福地是什么服务器
河南互动网络技术有限公司
网络安全知名企业
模拟环境在软件开发中的应用
sql怎么查两个数据库
ios系统期货软件开发
商道高手1元服务器
河南c语言软件开发如何收费
市两会期间网络安全保障报告
武汉专业冷库软件开发
深圳互联网研发科技公司
简述什么是数据库的后援副本
cnrds数据库要花钱吗
应用服务器的一般配置
服务器js文件放到哪里
服务器控件的方法
网络技术空间网
网络安全 灾难恢复
设备信息表数据库设计
获取服务器路径保存图片的方法
青岛利群大厦软件开发公司
广东惠普服务器虚拟化定制云主机
最安全的服务器搭建
计算机三级网络技术模拟卷
绍兴科优佰诺网络技术有限公司
怎么重启服务器管理工具
江苏常规软件开发推荐咨询
软件开发跟踪
数据库删表