1012 数字分类 (20 分)——数学
给定一系列正整数,请按要求对数字进行分类,并输出以下 5 个数字:
。。。。。
输入格式:
每个输入包含 1 个测试用例。每个测试用例先给出一个不超过 1000 的正整数 N,随后给出 N 个不超过 1000 的待分类的正整数。数字间以空格分隔。
输出格式:
对给定的 N 个正整数,按题目要求计算 A1~A5
并在一行中顺序输出。数字间以空格分隔,但行末不得有多余空格。
若其中某一类数字不存在,则在相应位置输出 N。
输入样例 1:
13 1 2 3 4 5 6 7 8 9 10 20 16 18
输出样例 1:
30 11 2 9.7 9
输入样例 2:
8 1 2 4 5 6 7 9 16
输出样例 2:
N 11 2 N 9
public class _1012 {
static Scanner in = new Scanner(new InputStreamReader(System.in));
public static void main(String[] args) {
int N = in.nextInt();
int A1 = 0;
int A2 = 0;
int A3 = 0;
int A5 = 0;
boolean b1=false,b2=false,b3=false,b4=false,b5=false; //判断是否存在该类数
int b=1;
double A4sum=0;
int k=0;
for (int i = 0; i < N; i++) {
int m = in.nextInt();
switch (m % 5) {
case 0:
if (m % 2 == 0) {
A1 += m;
b1=true; //特別注意要把这句放在if语句里面,
//之前放在if语句外面导致几个测试点没通过
}
break;
case 1:
b2=true;
A2+=m*b;
b=b*(-1);
break;
case 2:
b3=true;
A3++;
break;
case 3:
b4=true;
A4sum+=m; //这里先求出总和,最后再处理
k++;
break;
case 4:
b5=true;
if(m>A5) {
A5=m;
}
break;
}
}
String s=String.format("%.1f", A4sum/k);
System.out.print(b1?A1+" ":"N ");
System.out.print(b2?A2+" ":"N ");
System.out.print(b3?A3+" ":"N ");
System.out.print(b4?s+" ":"N ");
System.out.print(b5?A5:"N");
}
}