1. 程式人生 > 其它 >Java題解—1012 數字分類 (20 分)

Java題解—1012 數字分類 (20 分)

原題

跳轉地址
給定一系列正整數,請按要求對數字進行分類,並輸出以下 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。

程式碼

package pat;

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int N = scanner.nextInt();

        int case0=0,case1=0,case2=0,case3=0,case4=0;//接收每種情況的結果
        boolean flag0=false,flag1=false,flag2=false,flag3=false,flag4=false;//標誌某類數字是否存在
        int count=0;
        int massage1=0;
        //條件判斷
        for (int i=0;i<N;i++){
            int num = scanner.nextInt();
            switch (num%5){
                case 0:if (num%2==0){
                    case0+=num;
                    flag0=true;
                }
                    break;//注意,break要放if外面,才能跳出switch
                case 1:
                    massage1++;//計數用來交叉求和。因為奇數是加,偶數是減
                    if (massage1%2==0){
                        case1-=num;
                    }else {
                        case1+=num;
                    }
                    flag1=true;
                    break;

                case 2:case2++;flag2=true;break;

                case 3:
                    case3+=num;
                    flag3=true;
                    count++;
                    break;

                case 4:
                    if (num>case4){
                    case4=num;
                    flag4=true;
                }
                break;
            }
        }
        //輸出
        Object o;//注意:三元運算子與if不同的是,必須有一個變數來承載後面表示式的結果
        o=flag0 ? System.out.printf(case0+" "):System.out.printf("N ");
        o=flag1 ? System.out.printf(case1+" "):System.out.printf("N ");
        o=flag2 ? System.out.printf(case2+" "):System.out.printf("N ");

        double average=(double)case3/count;
        o=flag3 ? System.out.printf("%.1f",average):System.out.printf("N") ;
        o=flag4 ? System.out.printf(" "+case4):System.out.printf(" N");

    }
}