给定一系列正整数,请按要求对数字进行分类,并输出以下 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
这道题就是让咱们编五个小算法,都是比较简单的for循环遍历然后if语句之类的,要注意的就是输出格式和一些特殊情况的考虑,下面给出代码
#include<stdio.h>
#include<math.h>
int main()
{
//这次命名的变量太多了...不是要求五个数吗?所以我就把相关变量带上1,2,3,4,5,这样就好知道这个变量是用在哪的了
int n,sum1=0,count1=0,sum2=0,count3=0,count4=0,count5,max;
double sum4=0;
scanf("%d",&n);
int a[1001];
int b[1001]={0},c[1001]={0},count=0; //这里其实定义b[n],a[n],c[n]也行,我怕pat出问题就这样定义了,绝对满足它的要求
for(int i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
//A1
for(int i=0;i<n;i++)
{
if(a[i]%5==0 && a[i]%2==0) //遍历输进去的数,找到满足A1条件的数并记录个数
{
sum1=sum1+a[i];
count1++;
}
}
if(count1==0) //如果个数为0,输出N,注意这里不能sum1=0判断,因为可能正数负数相加为0,这时应输出0而不是N,下面也是一个意思,要用count个数判断,就不在重新说明
printf("N ");
else
printf("%d ",sum1);
//A2
for(int i=0;i<n;i++)
{
if(a[i]%5==1)
{
b[count]=a[i];
count++;
}
}
for(int i=0;i<count;i++)
{
sum2=sum2+b[i]*pow(-1,i);
}
if(count==0)
printf("N ");
else
printf("%d ",sum2);
//A3
for(int i=0;i<n;i++)
{
if(a[i]%5==2)
count3++;
}
if(count3==0)
printf("N ");
else
printf("%d ",count3);
//A4
for(int i=0;i<n;i++) //A4要注意一点,我们输出的result(平均数)是浮点型的,所以我们要定义浮点型的result和sum4,或者在sum4/count4前强制转换
{
if(a[i]%5==3)
{
count4++;
sum4=sum4+a[i];
}
}
double result;
result=sum4/count4;
if(count4==0)
printf("N ");
else
printf("%.1f ",result);
//A5
for(int i=0;i<n;i++)
{
if(a[i]%5==4)
{
c[count5]=a[i];
count5++;
}
}
max=c[0];
for(int i=0;i<count5;i++) //遍历满足条件的所有数,找到最大值
{
if(max<c[i])
{
int t=max;
max=c[i];
c[i]=t;
}
}
if(max==0)
printf("N"); //这会是输出最后一个数了,注意别带空格
else
printf("%d",max);
return 0;
}