给出10个数,使用某种排序方法,按照从小到大的顺序输出个个数。
根据要求,首先得给出这10个数,这里的算法需要一个循环,数据结构需要一个长度为10的整型数组。首先用BufferedReader in=new BufferedReader(new InputStreamReader(System.in));从键盘接收数据,然后定义一个数组int a[ ]=new int[10];用来存放数据,接下来就是将每个数字存入for(i=0;i<=9;i++){a[i] = Integer.parseInt(in.readLine()); }。然后就是排序了。凡是排序基本上都是二重循环。这里可以采用这种思路:从第一个数开始,每个数与它后面的那个数比较,把较小的放到前面,较大的放到后面。这样从前到后走一遍,最大的数就放到最后了。这样从第一个数到倒数第二个数就构成了外面的那层循环,即for(i=0;i<=8;i++)。而内层循环就是对下标为i的数来说,从它开始拿它和它后面的数比,小的放前面大的放后面。因为这里是以它后面的数到头为止,所以得另设一个整型变量j=i+1来表示“后面的数”的下标,故内层循环为for(j=i+1;j<=9;j++)。循环体按照小前大后的思路,用一个中间变量倒腾一下就行了if(a[i]>a[j]){t=a[i];a[i]=a[j];a[j]=t;}。
1 import java.io.*; 2 public class shiyan25 { 3 4 /** 5 * @param args 6 */ 7 public static void main(String[] args) { 8 try 9 { 10 BufferedReader in=new BufferedReader(new InputStreamReader(System.in)); 11 int i,n=10; 12 int a[ ]=new int[10]; 13 System.out.println("请输入10个整数:"); 14 for(i=0;i<=9;i++){ 15 a[i] = Integer.parseInt(in.readLine()); 16 } 17 int j,t; 18 for(i=0;i<=8;i++){ 19 for(j=i+1;j<=9;j++){ 20 if(a[i]>a[j]){ 21 t=a[i];a[i]=a[j];a[j]=t; 22 } 23 } 24 } 25 for(i=0;i<10;i++){ 26 System.out.print(a[i]+" "); 27 } 28 } 29 catch(Exception e){ 30 31 } 32 } 33 }