首页 > 其他分享 >PAT Basic 1012. 数字分类

PAT Basic 1012. 数字分类

时间:2023-03-07 11:23:44浏览次数:36  
标签:PAT 数字 temp int Basic else printf modNum 1012

PAT Basic 1012. 数字分类

1. 题目描述:

给定一系列正整数,请按要求对数字进行分类,并输出以下 5 个数字:

  • \(A1\) = 能被 5 整除的数字中所有偶数的和;
  • \(A2\) = 将被 5 除后余 1 的数字按给出顺序进行交错求和,即计算 \(n1−n2+n3−n4⋯\);
  • \(A3\) = 被 5 除后余 2 的数字的个数;
  • \(A4\) = 被 5 除后余 3 的数字的平均数,精确到小数点后 1 位;
  • \(A5\) = 被 5 除后余 4 的数字中最大数字。

2. 输入格式:

每个输入包含 1 个测试用例。每个测试用例先给出一个不超过 1000 的正整数 \(N\),随后给出 \(N\) 个不超过 1000 的待分类的正整数。数字间以空格分隔。

3. 输出格式:

对给定的 \(N\) 个正整数,按题目要求计算 \(A1\sim A5\) 并在一行中顺序输出。数字间以空格分隔,但行末不得有多余空格。

若分类之后某一类不存在数字,则在相应位置输出 N

4. 输入样例:

13 1 2 3 4 5 6 7 8 9 10 20 16 18
8 1 2 4 5 6 7 9 16

5. 输出样例:

30 11 2 9.7 9
N 11 2 N 9

6. 性能要求:

Code Size Limit
16 KB
Time Limit
400 ms
Memory Limit
64 MB

思路:

按照题目描述计算即可,\(A2\)的计算稍微麻烦些,这里我用a2Flag不断翻转符号位,另外注意因为\(A2\)是交错求和,所以即使其值为零也有可能存在这种数字,这里我用a2Count来标志是否存在这种数字。

My Code:

#include <stdio.h>
#define modNum 5

int main(void)
{
    int numNum = 0;
    int temp = 0;
    int A[5] = {0, 0, 0, 0, 0};
    unsigned char a2Flag = 1, a2Count = 0;
    int a4Count = 0;
    
    scanf("%d", &numNum);
    
    for(int i = 0; i < numNum; i++)
    {
        scanf("%d", &temp);
        
        if((temp % modNum == 0) && (temp % 2 == 0))
        {
             A[0] += temp;           
        }
        else if(temp % modNum == 1)
        {
            a2Count = 1;
            if(a2Flag)
            {
                A[1] += temp;
                a2Flag = 0;
            }
            else
            {
                A[1] -= temp;
                a2Flag = 1;
            }
        }
        else if(temp % modNum == 2)
        {
            A[2]++;
        }
        else if (temp % modNum == 3)
        {   
            a4Count++;
            A[3] += temp;
        }
        else if(temp % modNum == 4)
        {
            if(temp > A[4]) A[4] = temp;
        }
    }
    
    if(A[0]) printf("%d", A[0]);
    else printf("N");
    
    if(a2Count) printf(" %d", A[1]);
    else printf(" N");
    
    if(A[2]) printf(" %d", A[2]);
    else printf(" N");
    
    if(a4Count) printf(" %.1f", (float)A[3]/a4Count);
    else printf(" N");
    
    if(A[4]) printf(" %d", A[4]);
    else printf(" N");
     
    return 0;
}

标签:PAT,数字,temp,int,Basic,else,printf,modNum,1012
From: https://www.cnblogs.com/tacticKing/p/17187393.html

相关文章

  • 无线和射频集成电路CC2651R3SIPAT0MOUR/CC2652PSIPMOTR/CC2651P31T0RKPR TxRx + MCU 2
    一、CC2651R3SIPAT0MOUR介绍:CC2651R3SIPA器件是一款多协议2.4GHz无线微控制器(MCU),支持Zigbee®、Bluetooth®5.2LowEnergy、IEEE802.15.4g、TI15.4stack(2.4GHz)......
  • PAT 乙级 1014 题解 (Basic Level) Practice
    很简单的一道题,我的程序有点乱#include<stdio.h>#include<string.h>#include<ctype.h>intmain(){chars1[61];chars2[61];chars3[61];chars4[61];s......
  • 33. CF-Divisor Paths
    链接求从\(x\)到\(y\)的最短路径的数量。显然应该从\(x\)走到\(\gcd(x,y)\)再走到\(y\),容易证明这样走是最优的。那么现在只需要把两段的最短路径数量分别求出......
  • PAT Basic 1009. 说反话
    PATBasic1009.说反话1.题目描述:给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。2.输入格式:测试输入包含一个测试用例,在一行内给出总长度不超过80的......
  • Linux操作命令(九)1.comm命令 2.diff命令 3.patch命令
    1、comm用于比较两个有序文件的不同,在使用comm指令之前应先把文件的内容进行排序(sort)显示结果包括3列:第1列为只在第一个文件中找到的行,第2列为只在第二个文件中找......
  • fastjsonBasicDataSource链分析
    fastjsonBasicDataSource链分析(fastjson<=1.2.36)此利用链只能应用于fastjson<=1.2.36,在1.2.37版本中,直接去掉了key.toString方法。前置知识:首先我们看一下com.sun.or......
  • PAT 甲级 1009 Product of Polynomials
    Thistime,youaresupposedtofind A×B where A and B aretwopolynomials.InputSpecification:Eachinputfilecontainsonetestcase.Eachcaseoccupi......
  • 《设计模式之禅》Strategy_Pattern--策略模式
    写在前面设计模式之禅这本书也是博主看了几本设计模式的开头才决定以这本书作为学习设计模式的资料。像小傅哥的重学Java设计模式,好处是以真实的项目案例的逻辑来搭配设计模......
  • 高性能 Jsonpath 框架,Snack3 3.2.57 发布
    Snack3,一个高性能的JsonPath框架借鉴了Javascript所有变量由var申明,及Xmldom一切都是Node的设计。其下一切数据都以ONode表示,ONode也即Onenode之意,代表任何......
  • NetCore 之 DispatchProxy
    如何使用Dispatchproxy封装RESTAPI,让API调用更简单。1、创建HttpClientDispathProxy类继承自DispatchProxypublicclassHttpClientDispathProxy<TInterface>:D......