zoukankan      html  css  js  c++  java
  • Java排序

        给出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;}。

     

        完整代码如下:

    import java.io.*;
    public class shiyan25 {
    
        /**
         * @param args
         */
        public static void main(String[] args) {
            try
            {
                BufferedReader in=new BufferedReader(new InputStreamReader(System.in));
                int i,n=10;
                int a[ ]=new int[10];
                System.out.println("请输入10个整数:");
                for(i=0;i<=9;i++){
                    a[i] = Integer.parseInt(in.readLine());                
                }    
                int j,t;
                for(i=0;i<=8;i++){
                    for(j=i+1;j<=9;j++){
                       if(a[i]>a[j]){
                       t=a[i];a[i]=a[j];a[j]=t; 
                    }
                  }
               }
               for(i=0;i<10;i++){
                System.out.print(a[i]+" ");
               }
            }
            catch(Exception e){
                
            }
        }
    }

        

        效果如图:

  • 相关阅读:
    columns布局应用场景
    flex速记
    css属性选择器模糊匹配
    ydui的rem适配方案
    vscode搜索失效问题
    ESP8266 超声波测距模块HC-SR04
    树莓派PICO Wifi 无线网卡 esp82666接线图
    查看数据库容量大小
    面试官问我JVM内存结构,我真的是
    深入浅出Java内存模型
  • 原文地址:https://www.cnblogs.com/cysolo/p/3345320.html
Copyright © 2011-2022 走看看