public static void main(String[] args){
/*
冒泡排序由两层嵌套循环实现排序,外层循环数据对比轮数,内层循环控制每轮对比次数,每一轮依次减少一次对比次数,最终实现排序
*/
//乱序数组
int[] arr = {9,3,2,10,4,6};
//外层控制对比轮数
for(int i = 0; i < arr.length; i++) {
//内层循环控制每轮对比次数,每一轮依次减少一次对比次数,减1是因为数组最末尾数字无需对比且不减少1会出现数组下标越界
for(int j = 0; j < arr.length - i -1; j ++){
//升序排序(从小到大):如果J下标数字大于后面数字则交换位置,将大的数字往后排,否则保持不动
//降序排序(从大到小):如果J下标数字小于后面数字则交换位置,将小的数字往后排,否则保持不动
if (arr[j] > arr[j+1]) {
//定义临时变量,交换数字位置。
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
//打印排序结果
for (int i:arr) {
System.out.println(i);
}
}
java数组冒泡排序算法代码详解
最新推荐文章于 2024-08-26 09:09:41 发布