博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用蛮力法解决冒泡排序
阅读量:7008 次
发布时间:2019-06-28

本文共 1191 字,大约阅读时间需要 3 分钟。

hot3.png

冒泡排序蛮力法的另一个经典体现。

算法思想:比较列表中相邻的元素,如果是逆序的话,就交换他们的位置。重复多次之后,最大的元素就排到了最后一个位置。第二遍操作将第二个元素排到了倒数第二个位置上,这样一直依次比较下去,直到  n-1  遍之后,就排好了整个列表。

下面是我的代码实现:C++

#include using 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;i
Arr[j+1])//如果逆序,就交换 { temp=Arr[j]; Arr[j]=Arr[j+1]; Arr[j+1]=temp; } } } for(i=0;i

算法分析:输入的规模完全由N决定,基本操作是比较:Arr[j]>Arr[j+1],时间复杂度C(n)=Θ(n2).

但是键的交换次数是取决于特定的输入,最差的情况是与我们要求的排序相反的,这时候键的交换次数=键的比较次数=Θ(n2).

但是在有的输入情况下,如果在对列表比较一遍之后,没有交换元素的位置,那么这个列表已经有序了,我们就可以停止该算法了。具体改进版本如下:

#include using 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;i
Arr[j+1])//如果逆序,就交换 { temp=Arr[j]; Arr[j]=Arr[j+1]; Arr[j+1]=temp; change=true; } } if(!change)//没有发生交换,则不用继续比较了。 { break; } } for(i=0;i

但是在最差情况下,时间复杂度还是Θ(n2).

本文地址:编辑:王毅,审核员:逄增宝

转载于:https://my.oschina.net/u/3308739/blog/1585003

你可能感兴趣的文章
Codeforces Round #449 (Div. 2) A. Scarborough Fair【多次区间修改字符串】
查看>>
CCCC L1-039. 古风排版【图形输出/循环控制行列/模拟/细节】
查看>>
POJ 1182 食物链 【带权并查集/补集法】
查看>>
V字形
查看>>
Flask学习笔记(3)-数据库迁移
查看>>
Hbase常用操作
查看>>
一行命令学会全基因组关联分析(GWAS)的meta分析
查看>>
第二阶段冲刺——six
查看>>
模块封装代码
查看>>
《Machine Learning》(第一章)序章
查看>>
【右键禁用U盘的小技巧】
查看>>
执行sql语句后的数据处理api
查看>>
jquery $.each的用法
查看>>
Python --元组与列表的差异
查看>>
PHP TP增删改
查看>>
VMware虚拟机与主机联通及配置上网
查看>>
single-row function和muti-row function
查看>>
keepalived
查看>>
意向锁
查看>>
线性规划
查看>>