Java題解—1012 數字分類 (20 分)
阿新 • • 發佈:2021-10-14
原題
跳轉地址
給定一系列正整數,請按要求對數字進行分類,並輸出以下 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"); } }