给定一系列正整数,请按要求对数字进行分类,并输出以下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
思路:代码写的又臭又长,新手求谅解(●’◡’●) 这题主要考A2的判定问题,如果将A2==0作为判断,就要考虑交错求和出现0的情况
#include<cstdio>const int maxn=1010;int main(){ int N,x; int A1=0; int A2=0; int A3=0; double A4=0.0; int A5=0; int sum=0; int num=0; int cnt=0; int flag=-1; scanf("%d",&N); for(int i=0;i<N;i++){ scanf("%d",&x); switch(x%5){ case 0:{ if(x%2==0) A1+=x; break; } case 1:{ cnt++; flag*=-1; A2+=flag*x; break; } case 2:{ A3++; break; } case 3:{ num++; sum+=x; A4=(double)sum/num; break; } case 4:{ if(x>A5) A5=x; break; } } } if(A1!=0) PRintf("%d ",A1); else printf("N "); if(A2!=0||(A2==0&&cnt!=0))//注意A2是陷阱 printf("%d ",A2); else printf("N "); if(A3!=0) printf("%d ",A3); else printf("N "); if(A4!=0.0) printf("%.1lf ",A4); else printf("N "); if(A5!=0) printf("%d",A5); else printf("N"); return 0;}新闻热点
疑难解答