极简代码:1012 数字分类 (20分)
立志用更少的代碼做更高效的表達(dá)
給定一系列正整數(shù),請(qǐng)按要求對(duì)數(shù)字進(jìn)行分類(lèi),并輸出以下 5 個(gè)數(shù)字:
A?1 = 能被 5 整除的數(shù)字中所有偶數(shù)的和;
A2= 將被 5 除后余 1 的數(shù)字按給出順序進(jìn)行交錯(cuò)求和,即計(jì)算 n1 ?n?2?? +n3?? ?n?4?;
A?3= 被 5 除后余 2 的數(shù)字的個(gè)數(shù);
A?4= 被 5 除后余 3 的數(shù)字的平均數(shù),精確到小數(shù)點(diǎn)后 1 位;
A5= 被 5 除后余 4 的數(shù)字中最大數(shù)字。
輸入格式:
每個(gè)輸入包含 1 個(gè)測(cè)試用例。每個(gè)測(cè)試用例先給出一個(gè)不超過(guò) 1000 的正整數(shù) N,隨后給出 N 個(gè)不超過(guò) 1000 的待分類(lèi)的正整數(shù)。數(shù)字間以空格分隔。
輸出格式:
對(duì)給定的 N 個(gè)正整數(shù),按題目要求計(jì)算 A?1~A?5
?? 并在一行中順序輸出。數(shù)字間以空格分隔,但行末不得有多余空格。
若其中某一類(lèi)數(shù)字不存在,則在相應(yīng)位置輸出 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
簡(jiǎn)單模擬即可, 使用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; }每日一句
零星的變好,最后也會(huì)如星河般閃耀。
總結(jié)
以上是生活随笔為你收集整理的极简代码:1012 数字分类 (20分)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 9行代码AC——1011 A+B 和 C
- 下一篇: 样例解释:1013 数素数 (20分)