試題編號: | 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);
}
}
}
}