冒泡排序

来源:互联网 发布:docker容器连接数据库 编辑:程序博客网 时间:2024/06/06 03:45

冒泡排序是一种比较简单打排序算法,因为通过交换,每次把最大的值放到最后,像气泡一样冒出来,故而得名.

排序的规则:

数组a[n](n>1)

1.a[0]和a[1]比较,,如果a[0]大于a[1],交换a[0]和a[1]位置,直到a[n-1]和a[n]比较交换,筛选a[n]最大值

2.a[0]和a[1]比较,,如果a[0]大于a[1],交换a[0]和a[1]位置,直到a[n-2]和a[n-1]比较交换,筛选a[n-1]最大值

...

通过筛选,最终得到从小到大的数组

时间复杂度

最小的时间复杂度,假设数组本身就是正序排列,最小比较次数为n-1,移动次数0,所以最小的时间复杂度是O(n)

最大的时间复杂度,假设数组本身是逆序排列,最大比较次数n*(n-1)/2,最大的移动次数3n(n-1)/2,所以最大打时间复杂度是O(n^2)

java 代码实现

public static void sort(int[] a){if((a==null)||(a.length==0))        return;System.out.println("排序原始数组:"+Arrays.toString(a));for(int i=a.length-1;i>0;i--){for(int j=0;j<i;j++) {    if(a[j+1]<a[j]){    a[j+1]=a[j+1]^a[j];    a[j] = a[j+1]^a[j];    a[j+1]=a[j+1]^a[j];}}System.out.println("第"+(a.length-i)+"次排序结果:"+Arrays.toString(a));}}

完整代码及测试下载




0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 手机的调频调制器坏了怎么办 调制解调器的灯一直闪怎么办 691宽带用户名和密码无效怎么办 房间里有狐臭味怎么办 吃冰冻水果胃特别痛怎么办 小米5s屏幕闪烁怎么办 系统重装重启了怎么办 华为p10开不了机怎么办 眼镜腿夹的头疼怎么办 摩托车车头锁坏了怎么办 夏天骑摩托车戴头盔热怎么办 头盔玻璃罩边固定老是掉怎么办 电动车不戴头盔被扣车怎么办 郴州骑电动车没戴头盔怎么办 配置数据源时发现两个版本怎么办 微信占用内存3g怎么办 打印机显示内存已满怎么办 网页显示代理服务器连接失败怎么办 墙内线路断了怎么办 墙里的电线坏了怎么办 鱼竿最前端断了怎么办 下雨天墙壁与管道间漏水怎么办 电饭锅的电线被雨淋了怎么办 钢琴跨八度手短怎么办 弹钢琴手指不灵活怎么办呢? 理发剪不锋利了怎么办 室外宽带线断了怎么办 接宽带光纤太短怎么办 装修光纤网线太短怎么办 宽带入户线断了怎么办 电信有无线没网怎么办 墙里的网线断了怎么办 墙里网线断了怎么办 3根网线断了怎么办 剪了层次的头发怎么办 小米6充电线坏了怎么办 小米6导航信号弱怎么办 麦多多充不了电怎么办 一加数据线坏了怎么办 小米耳机泡水了怎么办 公司拖欠工资公司破产了怎么办