题目:

本题要求读入 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

思路:题目很简单,但是用python容易出现超时问题,下面是超时的代码,通过一个count函数很容易就得到对应的分数出现了几次,代码很简单,不详细讲了,下面有无超时的。

n = int(input())
a = list(map(int, input().split()))
b = list(map(int, input().split()))
result = []
for i in b[1:]:
    result.append(str(a.count(i)))
print(' '.join(result))

技巧:这个题目和之前几个容易超时的题目一样,在这里面像对数计数的,可以采用列表、字典等数据结构将所有可能出现的数据全部保存起来,然后对照去取出来就不会超时了,下面是无超时的代码。可以看一下之前几个题目的解法,多看几个,以后遇到这种问题就知道怎么处理了,在我发的文章中,出现了超时的文章就会标注。
这里将分数存储到一个列表中,列表的下标就对应着分数。代码很简单,不多讲解。

n = int(input())
a = list(map(int, input().split()))
grade = [0 for i in range(101)]
for m in a:
    grade[m] += 1
result = []
b = list(map(int, input().split()))
for n in b[1:]:
    result.append(str(grade[n]))
print(' '.join(result))