一.概念
冒泡排序,顾名思义,就是这一组数据像泡泡一样一个一个的浮出来。那么实现它呢,则是需要一遍遍的走访这组数据,然后把相连的数据两两比较,比较完后,把大的放在右边,小的放左边,然后重复逐一的比较,最后得到一组有序的数据。
二.实现
口诀:外层循环n (arr.length)内层循环 n-i (arr.length - i) n是指循环次数
public static int[] sort(int[] sourceArray) throws Exception {
// 对 arr 进行拷贝,不改变参数内容
int[] arr = Arrays.copyOf(sourceArray, sourceArray.length);
for (int i = 1; i < arr.length; i++) {
// 设定一个标记,若为true,则表示此次循环没有进行交换,也就是待排序列已经有序,排序已经完成。
boolean flag = true;
for (int j = 0; j < arr.length - i; j++) {
if (arr[j] > arr[j + 1]) {
int tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
flag = false;
}
}
if (flag) {
break;
}
}
return arr;
}
为什么内层循环要数组长度-i 呢 因为比较一次之后最右边的数 就是整个数组中最大的数了 以此类推 比一轮 右边就多一个固定位置的大值 所以 每外层循环一次 内层循环 就会减少一次 当外层循环i 次时内层循环就 n-i次