题要求读入 N 名学生的成绩,将得到某一给定分数的学生人数输出。 输入格式: 输入在第 1 行给出不超过 10^5 的正整数 N,即学生总人数。随后一行给出 N 名学生的百分制整数成绩,中间以空格分隔。最后一行给出要查询的分数个数 K(不超过 N 的正整数),随后是 K 个分数,中间以空格分隔。 输出格式: 在一行中按查询顺序给出得分等于指定分数的学生人数,中间以空格分隔,但行末不得有多余空格。 输入样例: 10 60 75 90 55 75 99 82 90 75 50 3 75 90 88 输出样例: 3 2 0
// PAT_1038_COUNT_GRADES_02 // 运行超时,用空间换时间 # include <stdio.h> # include <stdlib.h> # define Max 110 int main(void) { int n, k; int i; int val; scanf("%d",&n); int Grades[110]; // 将成绩数组初始化为0,表明给分数有多少人 for (i=0; i<Max; i++) { Grades[i] = 0; } // 记录每一个分数的人数 for (i=0; i<n; i++) { scanf("%d",&val); Grades[val] ++; } scanf("%d",&k); for (i=0; i<k; i++) { scanf("%d",&val); // 查找 printf("%d",Grades[val]); // 控制输出格式 if (i != k-1) printf(" "); } return 0; }
RRR数组