冒泡排序
一个长度为5的无序数组,按照从小到大的顺序排序后输出。
注意两个循环条件的不同
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int[] arr = new int[7];
for (int i = 0; i < arr.length; i++) {
arr[i] = scanner.nextInt();
}
scanner.close();
//遍历前n-1个元素
for(int i=0;i<arr.length-1;i++){
//遍历当前元素之后的所有元素
for(int j=i+1;j<arr.length;j++){
//如果后面的比当前元素小,则交换两者的值
if(arr[i]>arr[j]){
int temp=arr[i];
arr[i]=arr[j];
arr[j]=temp;
}
}
}
for (int k = 0;k < arr.length; k++) {
System.out.print(arr[k]+" ");
}
}
}
import java.util.Arrays;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int[] arr = new int[7];
for (int i = 0; i < arr.length; i++) {
arr[i] = scanner.nextInt();
}
scanner.close();
//第i趟比较
for(int i = 0; i < arr.length - 1; i++){
//开始进行比较,如果arr[j]比arr[j+1]的值大,那就交换位置
for(int j = 0; j < arr.length - i - 1; j++){
if(arr[j] > arr[j + 1]){
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
//输出
for (int k = 0;k < arr.length; k++) {
System.out.print(arr[k]+" ");
}
}
}