PAT (Basic Level) Practise (中文)1012. 数字分类 (20) C语言

1012. 数字分类 (20)

时间限制
50 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue

给定一系列正整数,请按要求对数字进行分类,并输出以下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>
    int main()
    {
    	int N,i,j=1,sum=0,cnt=0,flag=0;
    	int Number[1001]={0};
    	double A[6]={0};
    	scanf("%d",&N);
    	for(i=0;i<N;i++)
    	{
    		scanf("%d",&Number[i]);
    	}
    	for(i=0;i<N;i++)
    	{
    		switch(Number[i]%5)
    		{
    			case 0: 
    				if(Number[i]%2==0)
    				{
    					A[1]+=Number[i];
    				}	
    				break;
    			case 1: 
    				A[2]+=j*Number[i];/*A[2]=0不一定就要输出N,要加入一个flag记录*/ 
    				j*=-1;
    				flag++; 
    				break;
    			case 2:
    				A[3]++;
    				break;
    			case 3:
    				sum+=Number[i];
    				cnt++;
    				break;
    			case 4:
    				if(Number[i]>A[5]){
    					A[5]=Number[i];
    				}
    				break;
    			
    		}
    	}
    	if(cnt!=0)/*此处不加判断容易出错*/
    	{
    		A[4]=sum/(double)cnt;
    	}
    	
    	for(i=1;i<6;i++)
    	{
    		if(i==2)
    		{
    			if(flag==0)
    			{
    				printf("N");
    			}else
    			{
    				printf("%d",(int)(A[i]));	
    			}
    		}else if(i==4)
    		{
    			if(A[i]==0)
    			{
    				printf("N");
    			}else
    			{
    				printf("%0.1f",A[i]);	
    			}
    		}else
    		{
    			if(A[i]==0)
    			{
    				printf("N");
    			}else
    			{
    				printf("%d",(int)(A[i]));
    			}
    		}
    		if(i!=5)
    		{
    			printf(" ");
    		}
    	}
    
    	
    //	for(i=1;i<6;i++)
    //	{
    //		if(A[i]==0)
    //		{
    //			printf("N");
    //		}else
    //		{
    //			if(i==4)
    //			{
    //				printf("%0.1f",A[i]);
    //			}elseif(i==2)
    //			{
    //				if()
    //			}else
    //			{
    //				printf("%d",(int)(A[i]));
    //			}
    //		}
    //		if(i!=5){
    //			printf(" ");
    //		}
    //	}
    	
    	return 0;
    }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值