數(shù)字分類

題目描述

給定一系列正整數(shù),請(qǐng)按要求對(duì)數(shù)字進(jìn)行分類,并輸出以下5個(gè)數(shù)字:

A1 = 能被5整除的數(shù)字中所有偶數(shù)的和;

A2 = 將被5除后余1的數(shù)字按給出順序進(jìn)行交錯(cuò)求和,即計(jì)算n1-n2+n3-n4...;

A3 = 被5除后余2的數(shù)字的個(gè)數(shù);

A4 = 被5除后余3的數(shù)字的平均數(shù),精確到小數(shù)點(diǎn)后1位;

A5 = 被5除后余4的數(shù)字中最大數(shù)字。

輸入描述:

每個(gè)輸入包含1個(gè)測試用例。每個(gè)測試用例先給出一個(gè)不超過1000的正整數(shù)N,隨后給出N個(gè)不超過1000的待分類的正整數(shù)。數(shù)字間以空格分隔。

輸出描述:

對(duì)給定的N個(gè)正整數(shù),按題目要求計(jì)算A1~A5并在一行中順序輸出。數(shù)字間以空格分隔,但行末不得有多余空格。

若其中某一類數(shù)字不存在,則在相應(yīng)位置輸出“N”。

輸入例子:

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

輸出例子:

30 11 2 9.7 9


C語言版:

#include<stdio.h>
int main(void){
    double arr[5] = {0, 0, 0, 0, 0};
    int num;
    scanf("%d", &num);
    int val;
    int pm = 1;
    int n = 0;
    for(int i=0; i<num; i++){
        scanf("%d", &val);
        switch(val % 5){
            case 0:
                if(val % 2 ==0){
                    arr[0] += val;
                }
            break;
            case 1:
                arr[1] += pm * val;
                pm *= -1;
            break;
            case 2:
                arr[2]++;
            break;
            case 3:
                arr[3] += val;
                n++;
            break;
            case 4:
                if(val > arr[4]){
                    arr[4] = val;
                }
            break;
        }
    }
    for(int j=0; j<4; j++){
        if(arr[j] == 0){
            printf("N ");
        }
        else if(j == 3){
            arr[j] = arr[j] / n;
            printf("%0.1f ", arr[j]);
        }
        else{
            printf("%0.0f ", arr[j]);
        }
    }
    if(arr[4] == 0){
        printf("N");
    }
    else{
        printf("%0.0f", arr[4]);
    }
    return 0;
}

注意:

  • 注意格式,PAT的大多數(shù)題都要求數(shù)字和數(shù)字之間用空格隔開,而最后一個(gè)數(shù)字的末尾是沒有空格的。

C++版:

#include<iostream>
#include<iomanip>
using namespace std;
int main(void){
    double arr[5] = {0, 0, 0, 0, 0};
    int num;
    cin >> num;
    int val;
    int pm = 1;
    int n = 0;
    for(int i=0; i<num; i++){
        cin >> val;
        switch(val % 5){
            case 0:
                if(val %2 == 0){
                    arr[0] += val;
                }
            break;
            case 1:
                arr[1] += pm * val;
                pm *= -1;
            break;
            case 2:
                arr[2]++;
            break;
            case 3:
                arr[3] += val;
                n++;
            break;
            case 4:
                if(val > arr[4]){
                    arr[4] = val;
                }
            break;
        }
    }
    for(int j=0; j<4; j++){
        if(arr[j] == 0){
            cout << "N ";
        }
        else if(j == 3){
                arr[j] = arr[j] / n;
                cout << setiosflags(ios::fixed) << setprecision(1) << arr[j] << " ";
            }
        else{
            cout << arr[j] << " ";
        }
    }
    if(arr[4] == 0){
            cout << "N";
        }
        else{
            cout << setprecision(0) << arr[4];
        }
}

注意:

  • 在一般的算法題中,C和C++基本沒有區(qū)別,因?yàn)橛貌坏健?strong>類”這個(gè)概念(所以這里的C++只是把stdio里的方法換成iostream里的方法)。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容