给定一系列正整数,请按要求对数字进行分类,并输出以下 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。
输入样例 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
注意:
1、A1是符合条件的偶数的和
2、A2–>有可能运算的结果本身就是0,所以要判断count是否为0,若为0则输出“N”
3、A4–>要注意,若该类数字不存在时分母为0,需要单独讨论
4、A5如果你是用max()的话,别忘了集合为空这种情况
代码片
t=input().split()
n=int(t[0])
A=[0,0,0,0,0]
p=sum=count=0
x=set()
for i in range(1,len(t)):
list=int(t[i])
if list%10==0:
A[0]+=list
elif list%5==1:
A[1]+=list*(-1)**p
p += 1
elif list%5==2:
A[2]+=1
elif list%5==3:
A[3]+=list
count+=1
elif list%5==4:
if list>A[4]:
A[4]=list
if count>0:
A[3]=A[3]/count
if A[0]==0:
A[0]="N"
if p==0:
A[1]="N"
if A[2]==0:
A[2]="N"
if A[3]==0:
A[3]="N"
else:
A[3]='%.1f'%float(A[3])
if A[4]==0:
A[4]="N"
print(A[0],A[1],A[2],A[3],A[4])
exit(0)