题3:成绩单(result.cpp/in/out)
【问题描述】
又考试了,这次考试的人数特别多,每个人的学号很特别,是用字符串表示的(不超过30位),每次考试结束后,成绩统计是一件很重要的事情。
老师们都很关心学生的成绩,于是他们把学生的成绩按学号排列(字典顺序,学号全为小写字母,从小到大排列)(不排成绩),并统计各个分数,及分数段的人数,以及满分人员(满分要奖励XXX奖学金的)。
【输入格式】
第一行:一个数n(n<=130000人)。
以下n行:每行两个信息,分别为学号,分数(1~150分)。
【输出格式】
第一行:各个分数段(空格隔开)(例如1~10 11~20„„(见例样,不包括150分的人数)。
第二行:各个分数段的人数(空格隔开,没有则输出0)。
接下来的n行,分别为n个学生的学号,成绩,(空格隔开)。
再接下来的一行为满分的人的人数x(如果没有则为0)(保证x不超过10000)。
接下来的x行为满分人的学号(如果x为0则为一行‘No’)(按字典序从小到大排序)。
注意:
一行若有多个数据,每一个数据之间用空格隔开,最后一个数据后不允许有空格。分数段中没有0分和150分的。
【样例输入】
3
bid 50
wxy 85
alc 55
【样例输出】
1~9 10~19 20~29 30~39 40~49 50~59 60~69 70~79 80~89 90~99 100~109 110~119 120~129 130~139 140~149
0 0 0 0 0 2 0 0 1 0 0 0 0 0 0
alc 55
bid 50
wxy 85
0
No
【提示】
无(个人提示:注意字母大小写!)
下面是这个题的思路QWQ
先将每个人的学号和成绩进行输入,记录满分的同学个数,并且统计各分数段相应的人数,之后将每个人的名字根据字典序排序,然后根据题目要求输出分数段和每个分数段的人数,再输出每个人的名字与成绩,然后输出满分的人数和满分同学的学号(如果没有,这输出No)
下面是ac题解
#include<cstring>
#include<cstdio>
#include<iostream>
#include<algorithm>
using namespace std;
int n,s[20]={},shigh=0;//shigh用于记录满分的人数
struct node{
string name;
int score;
}a[130000];//用结构体方便输出学号与成绩
bool cmp(node x,node y) //排序的函数
{
return(x.name<y.name);
}
int main()
{
// freopen("result.in","r",stdin);
// freopen("result.out","w",stdout);
cin>>n;
for(int i=1;i<=n;i++)
{
cin>>a[i].name>>a[i].score;
if(a[i].score==150)
shigh++;//统计满分人数
s[a[i].score/10]++;//统计每个分数段的人数
}
cout<<"1~9 10~19 20~29 30~39 40~49 50~59 60~69 70~79 80~89 90~99 100~109 110~119 120~129 130~139 140~149"<<endl;
for(int i=0;i<=14;i++)
printf("%d ",s[i]);
cout<<endl;
sort(a+0,a+n+1,cmp);//根据字典序进行排序
for(int i=1;i<=n;i++)
cout<<a[i].name<<" "<<a[i].score<<endl;
cout<<shigh<<endl;
if(shigh==0) //没有满分输出“No”
cout<<"No"<<endl;
else//有满分的情况
{
for(int i=1;i<=n;i++)
if(a[i].score==150)
cout<<a[i].name<<endl;
}
return 0;//结束
}