9.21
数列排序
问题描述
给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
输入格式
第一行为一个整数n。
第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
输出格式
输出一行,按从小到大的顺序输出排序后的数列。
样例输入
5
8 3 6 4 9
样例输出
3 4 6 8 9
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();//存储数列长度
while(n<1 || n>200) {//n的范围验证
n = sc.nextInt();
}
int []a = new int [n];//定义数列
for(int i=0;i<n;i++) {//输入数列
a[i] = sc.nextInt();
while(Math.abs(a[i])>10000) {//数组值范围验证
System.out.print("每个整数的绝对值小于10000,请重新输入:");
a[i] = sc.nextInt();
}
}
for(int i=0;i<a.length-1;i++) {//冒泡排序
for(int j=0;j<a.length-i-1;j++) {
if(a[j]>a[j+1]) {
int t = a[j];
a[j] = a[j+1];
a[j+1] = t;
}
}
}
for(int i=0;i<a.length;i++) {
System.out.print(a[i]+" ");
}
}
浙公网安备 33010602011771号