CCF-201903-1小中大

试题编号: 201903-1
试题名称: 小中大
时间限制: 1.0s
内存限制: 512.0MB
问题描述:

需要注意的几个地方:

1.可能存在连续几个整数相等。(所以不能比较数组第一个和第二个= =估计也就我这么蠢的才会这样比较了)

2.如果N是奇数,直接输出中位数,强制类型转换吧。如果N是偶数,中位数计算以后如果是整数强制类型转换,如果是分数保留一位小数。(= =死在这里两次了)

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner s = new Scanner(System.in);
        int n = s.nextInt();
        int[] a  = new int[n];
        for (int i = 0; i<n; i++) {
            a[i] = s.nextInt();
        }
        s.close();
        int min,max;
        double med;
//判断序列是升序还是降序,可以得到最大值和最小值。
        if(a[0]<a[n-1]){
            min = a[0];
            max = a[n-1];
        }
        else{
            min = a[n-1];
            max = a[0];
        }
//如果N是奇数,那么直接输出中位数。(强制类型转换为Int)
        if(n%2==1){
            med = a[n/2];
            System.out.print(max+" "+(int)med+" "+min);
        }
//如果N是偶数,先计算出中位数,然后判断是不是整数。
        else {
            med=(a[n/2-1]+a[n/2])/2.0;
            if(med==(int)med){
                int med1 = (int)med;
                System.out.println(max+" "+med1+" "+min);
            }else{
                                //这里是保留一位小数
                String med1 = String.format("%.1f",med);
                System.out.println(max+" "+med1+" "+min);
            }
        }

    }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章