简化版的桶排序很浪费空间,我们为了解决浪费空间的问题,引入冒泡排序。冒泡排序的基本思想是:每次比较相邻的两个数据,如果顺序错误就把他们交换。
举一个简单的栗子:比如我待排序的数组是arr[12,35,99,18,76],我们的需求是按照从大到小数据排序。
排序的过程:
第一趟冒泡排序结果[35,99,18,76,12].首先我们通过冒泡排序的想象模拟排序的过程:
12和35交换交换后的结果是:[35,12,99,18,76].
12和99交换交换后的结果是[35,99,12,18,76].
12和18交换交换后的结果是[35,99,18,12,76].
12和76比较交换交换后的结果:[35,99,18,76,12].
OK,12这个数据已经排序完成,重复上面的操作直到数据排序完成。
冒泡排序的原理是:每一趟只能确定一个数归位。总结如下:如果有n个数进行排序,只需要将n-1个数归位,也就是说要进行n-1趟操作,而且每一趟都需要从第一位开始进行相邻两个数比较,将较小的数字放在后面,比较完毕后挪一位继续比较下面两个相邻数的大小,重复此步骤知道最后一个尚未归位的数。已经归位的数字则无需进行比较。
public class MaoPao {
public static void main(String[] args) {
int [] arr={12,35,99,18,76};
maoPao(arr);
printArray(arr);
}
private static void maoPao(int[] arr) {
for (int i=arr.length-1;i>0;i--) {
for (int j=0;j<i;j++) {
if (arr[j]<=arr[j+1]) {
swap(arr,j,j+1);
}
}
}
}
public static void swap(int[] arr, int i, int j) {
arr[i] = arr[i] ^ arr[j];
arr[j] = arr[i] ^ arr[j];
arr[i] = arr[i] ^ arr[j];
}
public static void printArray(int[] arr) {
if (arr == null) {
return;
}
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
System.out.println();
}
}
网友评论