排序算法之优化版冒泡排序

  优化版的冒泡排序加入了一个boolean标志位,若排序已经完成,即没有发生数据交换,则标志位为false,不必去遍历后面的数据,最小时间复杂度O(n),最大时间复杂度为O(n^2).
     思路:这里的排序替换是从数组的最后一位开始,依次于前一位进行比较,比如数组长度为10.则是array[9]与array[8]比较,如果9的值大于8.交换,标志位置为true,然后是8与7比较,依次类推,当1与0比较交换之后,第一轮比较结束,此时 i ++,i值发生变化,所以在第二轮循环只能进行到2与1比较,第二个for的条件限制了最后的比较位数,即此时j >= 2。因为上轮比较后最大的值放在了第0位,第二轮则同第一轮原理,将剩余的进行比较,将第二大数放在了1的位置,依次类推,如同最大气泡上浮一般,完成冒泡排序。
标志位的作用:一但在某轮循环中,依次比较之后发现前一位数总是大于后一位数,所以没有必要再循环比较(例:若从7开始,前一位数总是大于后一位数,因此没有比较在下一次循环中从6开始再次去和前一位去比较)因而if()代码块不会执行,则标志位的值仍为第一层for循环的值false,回到第一层循环之后,由循环条件判断不成立,退出循环,完成冒泡排序。
public void bubbleSort(int[] array){
     boolean flag = true;
     for(int i = 1;i < array.length && flag;i ++){
          flag = false;
          //n个数,则比较n-1次
          for(int j = array.length - 1;j >= i;j --){
               if(array[j] > array[j - 1]){
                   int num = array[j];
                   array[j] = array[j - 1];
                   array[j - 1] = num;
                   flag = true; 
               }
          }
     }
     System.out.println("bubbleSort "+Array.toString(array));
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值