试题编号: | 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);
}
}
}
}