package JavaClassTest1; //测试冒泡排序
/*********************
* int[] num = {23,45,76,78,98,54,};
第一次 23 45 76 78 54 98
第二次 23 45 76 54 78 98
第三次 23 45 54 76 78 98
输出 :23 45 54 76 78 98
当判断为正确时就退出循环
*********************/
public class TestMaoPaoPaiXu {
public static void main(String[] args) {
//Scanner reader = new Scanner(System.in);
// int[] num = {3,4,6,8,9};
int[] num = {23,45,76,78,98,54,};
// for(int a : num) {
// System.out.print(a + " ");
// }
// System.out.println();
boolean flog = true;
for(int i = 1;i < num.length&&flog;i++) { //num.length个元素,终须只需循环num.length-1次
flog = false;
for(int j = 0;j < num.length - i;j++) { //每循环一次,就可以少调换一次,因为最大的数排在最后不用换
if(num[j] > num[j + 1]) {////注意此处不是i,而是j,如果是i,会提示越界
int s= num[j];
num[j] = num[j + 1];
num[j + 1] = s;
flog = true;
}
}
for(int a : num) //注意这个输出for语句放在外层for里面
System.out.print(a + " ");
System.out.println();
}
}
}
1