C++中如何使用蛮力法求解冒泡排序
发表于:2024-11-13 作者:千家信息网编辑
千家信息网最后更新 2024年11月13日,本篇内容介绍了"C++中如何使用蛮力法求解冒泡排序"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!算法
千家信息网最后更新 2024年11月13日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安全错误
数据库的锁怎样保障安全
公司网络安全自查项
紫鸟浏览器是服务器吗
aws服务器鹤乡文字聊天室
电子信息工程计算机网络技术
重庆市万州网络安全职业学校
什么情况下需要用到数据库测试
网络安全发展趋势和新技术
南宫崇雨网络技术有限公司
饥荒联机使用的服务器不可用
sql 库数据库
数据库提供程序
浅谈网络安全与管理
现在网络技术的发展
lol服务器在哪
负责数据库中查询操作
西安英慧达网络技术有限公
互联网最科技前沿site
超级推荐要看什么数据库
佛山保洁服务软件开发报价
食材分拣系统软件开发
计算机网络安全管理学考研
手机硬盘怎么改内存数据库
dos查看服务器的配置信息
ac1900能做打印服务器吗
山东省七项网络安全责任
数据库 自增
关系型数据库知乎
网络安全公司的股东
绝地求生哪个区服务器好
商品详情数据库