极简代码:1012 数字分类 (20分)
生活随笔
收集整理的這篇文章主要介紹了
极简代码:1012 数字分类 (20分)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
立志用更少的代碼做更高效的表達
給定一系列正整數,請按要求對數字進行分類,并輸出以下 5 個數字:
A?1 = 能被 5 整除的數字中所有偶數的和;
A2= 將被 5 除后余 1 的數字按給出順序進行交錯求和,即計算 n1 ?n?2?? +n3?? ?n?4?;
A?3= 被 5 除后余 2 的數字的個數;
A?4= 被 5 除后余 3 的數字的平均數,精確到小數點后 1 位;
A5= 被 5 除后余 4 的數字中最大數字。
輸入格式:
每個輸入包含 1 個測試用例。每個測試用例先給出一個不超過 1000 的正整數 N,隨后給出 N 個不超過 1000 的待分類的正整數。數字間以空格分隔。
輸出格式:
對給定的 N 個正整數,按題目要求計算 A?1~A?5
?? 并在一行中順序輸出。數字間以空格分隔,但行末不得有多余空格。
若其中某一類數字不存在,則在相應位置輸出 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
簡單模擬即可, 使用switch提高效率。
代碼展示
#include <stdio.h> int main() {int x1 = 0, x2 = 0, x3 = 0, x4 = 0, x5 = 0;int x2flag = 0, x4count = 0;int count; scanf("%d", &count);for(int i = 0, n; i < count; i++) {scanf("%d", &n);switch(n % 5) {case 0: x1 += n % 2 ? 0 : n; break;case 1: x2flag = x2flag == 1 ? -1 : 1; x2 += x2flag * n; break;case 2: x3 ++; break;case 3: x4 += n; x4count ++; break;case 4: x5 = n > x5? n : x5; break;}}if(x1 == 0) printf("N "); else printf("%d ", x1);if(x2flag == 0) printf("N "); else printf("%d ", x2);if(x3 == 0) printf("N "); else printf("%d ", x3);if(x4 == 0) printf("N "); else printf("%.1f ", x4 * 1.0 / x4count);if(x5 == 0) printf("N"); else printf("%d", x5);return 0; }每日一句
零星的變好,最后也會如星河般閃耀。
總結
以上是生活随笔為你收集整理的极简代码:1012 数字分类 (20分)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 9行代码AC——1011 A+B 和 C
- 下一篇: 样例解释:1013 数素数 (20分)