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);
            }
        }

    }
}

 

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