题目链接:
1038 统计同成绩学生
思路:
用Hash散列,分数总共只有101种可能,用分数值作为数组下标,设置g[101],然后记录分数出现的次数就ok啦~
友情提示:
测试点3如果用cin,cout的话会超时,全部改成scanf和printf就可以通过测试点3啦!
代码如下:
#include<iostream>
#include<cstring>
using namespace std;
int g[101]={0};
int main()
{
long n;
int grade;
scanf("%ld",&n);
// memset(g,0,sizeof(g));
for(long i=0;i<n;i++)
{
scanf("%d",&grade);
g[grade]++;
}
int k;
scanf("%d",&k);
int find_grade[k];
for(int i=0;i<k;i++)
{
scanf("%d",&find_grade[i]);
}
for(int i=0;i < k;i++)
{ if(i==k-1)
{
printf("%d",g[find_grade[i]]);
break;
}
printf("%d ",g[find_grade[i]]);
}
return 0;
}