优化版的冒泡排序加入了一个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));
}