给定一系列正整数,请按要求对数字进行分类,并输出以下5个数字: A1 = 能被5整除的数字中所有偶数的和; A2 = 将被5除后余1的数字按给出顺序进行交错求和,即计算n1-n2+n3-n4...; A3 = 被5除后余2的数字的个数; A4 = 被5除后余3的数字的平均数,精确到小数点后1位; A5 = 被5除后余4的数字中最大数字。
输入描述:
每个输入包含1个测试用例。每个测试用例先给出一个不超过1000的正整数N,随后给出N个不超过1000的待分类的正整数。数字间以空格分隔。
输出描述:
对给定的N个正整数,按题目要求计算A1~A5并在一行中顺序输出。数字间以空格分隔,但行末不得有多余空格。 若其中某一类数字不存在,则在相应位置输出“N”。
输入例子:
13 1 2 3 4 5 6 7 8 9 10 20 16 18
输出例子:
30 11 2 9.7 9
代码
#include <iostream>
#include <stdio.h>
using namespace std;
int
main (){
int
A1=
0
,A2=
0
,A3=
0
,A5=
0
;
float
A4=
0.0
;
int
n ;
cin>>n;
long
a[n];
long
b[n];
int
i;
int
t=
0
;
int
count=
0
;
for
(i=
0
;i<n;i++){
cin>>a[i];
b[i]=
0
;
}
for
(i=
0
;i<n;i++){
if
(a[i]%
10
==
0
){
A1+=a[i];
}
if
(a[i]%
5
==
1
){
b[t++]=a[i];
}
if
(a[i] %
5
==
2
){
A3++;
}
if
(a[i] %
5
==
3
) {
A4 = A4 + a[i];
count++;
}
if
(a[i] %
5
==
4
){
if
(A5 < a[i]){
A5 = a[i];
}
}
}
for
(
int
i =
0
; i < t; i++) {
if
(i ==
0
|| i %
2
==
0
) {
A2 = A2 + b[i];
}
else
{
A2 = A2 - b[i];
}
}
if
(count==
0
){
count=
1
;
}
A4 = A4/count;
if
(A1 ==
0
)
cout <<
"N "
;
else
cout << A1 <<
" "
;
if
(A2 ==
0
)
cout <<
"N "
;
else
cout << A2 <<
" "
;
if
(A3 ==
0
)
cout <<
"N "
;
else
cout << A3 <<
" "
;
if
(A4 ==
0
)
cout <<
"N "
;
else
printf(
"%.1f "
,A4);
if
(A5 ==
0
)
cout <<
"N"
;
else
cout << A5;
return
0
;
}