目录
1、前言
2、冒泡排序
2.1 算法思路
2.2 代码实现过程:
3、代码优化
3.1 趟数优化
3.2 循环次数优化
3.3 排序完成优化
4、结语
我们书接上回,接着数组中的遗留问题来讲解这节的冒泡排序,干货满满,里面还涉及到代码的优化,希望大家有所收获
public static void main7(String[] args) {
int[] array = {10,5,3,7,6};
myBubblesort(array);
System.out.println(Arrays.toString(array));
}
public static void myBubblesort(int[] array){
for (int i = 0; i < array.length; i++) {
for (int j = 0; j < array.length-1; j++) {
if(array[j] > array[j+1]){
int tmp = 0;
tmp = array[j];
array[j] = array[j+1];
array[j+1] = tmp;
}
}
}
}
当j = 0时,此时array[0] = 10; array[1] = 5;10 > 5,所以执行array[j] = array[j+1]的交换代码(这里交换代码简写,下同),数组变为:{5,10,3,7,6};
当j = 1时,此时array[1] = 10; array[2] = 3;10 > 3,所以执行array[j] = array[j+1]的交换代码,数组变为{5,3,10,7,6};
当j = 2时,此时array[2] = 10; array[3] = 7;10>7,所以执行array[j] = array[j+1]的交换代码,数组变为{5,3,7,10,6};
当j = 3时,此时array[3] = 10; array[4] = 6;10>6,所以执行array[j] = array[j+1]的交换代码,数组变为{5,3,7,6,10};
至此第1趟的内部循环结束,我们将10这个数字排列到数组的末尾,此时j循环了4次,j = 3时停止。
我们发现,数组中一共有5个元素,j循环了4次,那么第一个循环条件就是j
当j = 0时,此时数组是上一趟结束的数组{5,3,7,6,10},此时array[0] = 5; array[1] = 3;5 > 3,所以执行array[j] = array[j+1]的交换代码,数组变为:{3,5,7,6,10};
当j = 1时,此时array[1] = 5; array[2] = 7;5 < 7,所以不执行array[j] = array[j+1]的交换代码,数组还是{3,5,7,6,10};
当j = 2时,此时array[2] = 7; array[3] = 6;7 > 6,所以执行array[j] = array[j+1]的交换代码,数组变为{3,5,6,7,10};
至此第2趟代码就执行完交换了,因为当j = 3的时候,我们比较的是7和10的大小,在第一趟的时候,我们就已经操作完10到数组的末尾了,所以没必要再比较一次。
在第2趟中我们将7操作到倒数第二位的指定位置,我们发现内部循环j执行了3次,到j = 2时候停止。 其实到第2趟的时候我们已经排序完成了,但是代码不知道这个事情(这点记下来,可以做代码优化),我们接着执行第3趟
当j = 0时,此时数组是上一趟结束的数组{3,5,6,7,10},此时array[0] = 3; array[1] = 5;3 < 5,所以不执行array[j] = array[j+1]的交换代码,数组还是{3,5,6,7,10}。
当j = 1时,此时array[1] = 5; array[2] = 6;5 < 6,所以不执行array[j] = array[j+1]的交换代码,数组还是{3,5,6,7,10}。
至此第3趟的内部循环就结束了,因为如果再往下执行,就要操作7了,但是7我们在第2趟的时候已经操作过了。
在第3趟的内部循环中,是操作了6在倒数第3位的位置,我们发现内部循环j执行了2次,到j = 1时候停止。 数据早就排序好了,但是代码不知道,所以继续第4趟。
当j = 0时,此时数组是上一趟结束的数组{3,5,6,7,10},此时array[0] = 3; array[1] = 5;3 < 5,所以不执行array[j] = array[j+1]的交换代码,数组还是{3,5,6,7,10}。
至此第4趟结束了,因为我们要操作的是5这个数字,和3比较完之后,就已经在原来正确的位置了,所以循环结束。
在第4趟的内部循环中,是操作了5在倒数第4位的位置,我们发现内部循环j执行了1次,到j = 0时候停止。
注意:我们要不要执行第5趟呢,这个问题放在代码优化中讲解。
public static void main7(String[] args) {
int[] array = {10,5,3,7,6};
myBubblesort(array);
System.out.println(Arrays.toString(array));
}
public static void myBubblesort(int[] array){
for (int i = 0; i < array.length-1; i++) {
for (int j = 0; j < array.length-1; j++) {
if(array[j] > array[j+1]){
int tmp = 0;
tmp = array[j];
array[j] = array[j+1];
array[j+1] = tmp;
}
}
}
}
public static void main7(String[] args) {
int[] array = {10,5,3,7,6};
myBubblesort(array);
System.out.println(Arrays.toString(array));
}
public static void myBubblesort(int[] array){
for (int i = 0; i < array.length-1; i++) {
for (int j = 0; j < array.length-i-1; j++) {
if(array[j] > array[j+1]){
int tmp = 0;
tmp = array[j];
array[j] = array[j+1];
array[j+1] = tmp;
}
}
}
}
public static void main7(String[] args) {
int[] array = 10,5,3,7,6};
myBubblesort(array);
System.out.println(Arrays.toString(array));
}
public static void myBubblesort(int[] array){
for (int i = 0; i < array.length-1; i++) {
boolean flg = false;
for (int j = 0; j < array.length-1-i; j++) {
if(array[j] > array[j+1]){
int tmp = 0;
tmp = array[j];
array[j] = array[j+1];
array[j+1] = tmp;
flg = true;
}
}
if(flg == false){
return;
}
}
}