給定一系列正整數,請按要求對數字進行分類,並輸出以下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
#include <stdio.h>
#include <stdlib.h>
int nagtive(int time){
int num = 1;
for(int i = 0; i < time; i ++){
num *= -1;
}
return num;
}
int A1;
int a1;
int A2;
int A3;
float A4;
int A5;
int main(){
int num;
int i = 1;
int j = 0;
//printf("%d\n",nagtive(2));
int N;
scanf("%d",&N);
for(int m = 0; m < N; m ++){
scanf("%d",&num);
if(num % 5 == 0){
if(num % 2 == 0){
a1 ++;
A1 += num;
}
}else if(num % 5 == 1){
i ++;
num = num * nagtive(i);
A2 += num;
}else if(num % 5 == 2){
A3 ++;
}else if(num % 5 == 3){
//printf("num:%d A4:%0.1f j:%d\n",num,A4,j);
j ++;
float i = num;
A4 = A4 + i;
//printf("num:%d A4:%0.1f j:%d\n",num,A4,j);
}else{
if(num > A5)
A5 = num;
}
}
//printf("A4:%0.1f j:%d\n",A4,j);
if(j != 0){
float i = j;
A4 = A4 / i;
}
//printf("A4:%0.1f j:%d\n",A4,j);
if(a1 == 0)
printf("N ");
else
printf("%d ",A1);
if(i == 1)
printf("N ");
else
printf("%d ",A2);
if(A3 == 0)
printf("N ");
else
printf("%d ",A3);
if(j == 0)
printf("N ");
else
printf("%0.1f ",A4);
if(A5 == 0)
printf("N");
else
printf("%d",A5);
}
竟然忽視了題中是要求先輸入數字的個數了,這種錯都能有。