1.基本介绍
冒泡排序(Bubble Sorting)的基本思想是:通过对待排序序列从前向后(从下表较小的元素开始),依次比较相邻元素的值,若发现逆序则交换,使值较大的元素逐渐从前移向后部,就像水底下的气泡一样逐渐向上冒。因为排序的过程中,个元素不断接近自己的位置,如果一趟比较下来没有进行过交换,就说明序列有序,因此要在排序过程中设置一个标志flag判断元素是否进行过交换。从而减少不必要的比较。
2.示例图
3.冒泡代码演示
@Test
public void testSort(){
//我们来测一下各种排序速度
int[] array = new int[100000];
for (int i = 0; i < array.length; i++) {
array[i] = (int) (Math.random()*100000);
}
long start = System.currentTimeMillis();
bubbleSorting(array);//冒泡排序排序100000个数总耗时17984毫秒
long end = System.currentTimeMillis();
System.out.println("总共耗时:"+(end-start));
}
//冒泡排序
public void bubbleSorting(int[] array) {
boolean flag = true;
for (int i = 0; i < array.length - 1; i++) {
for (int j = 0; j < array.length - 1 - i; j++) {
//如果前面的数比后面的数大,则交换
if (array[j] > array[j+1]) {
int temp = array[j];
array[j] = array[j+1];
array[j+1] = temp;
flag = false;
}
}
//如果某次循环没有进行过交换,则结束循环
if (flag) {
break;
}
flag = true;
}
}