问题描述
四年级二班女同学在体育课上进行了一轮仰卧起坐测试。成绩计算表如下。
一分钟内做仰卧起坐的个数 成绩
<20个 F
20~29个 E
30~39个 D
40~49个 C
50~59个 B
>=60个 A
请从键盘读入 𝑛n 位同学的在一分钟内做仰卧起坐的数量,计算出每个成绩区间的人数,按照人数降序排序,如果有多个成绩区间人数一样多,那么先输出成绩较好的区间。( 4.1.444.1.44 )
输入
第一行是一个整数 𝑛n 代表同学的人数( 𝑛≤100n≤100 );
第二行是 𝑛n 个同学一分钟完成仰卧起坐的数量。
输出
输出 66 行为 66 个成绩区间的人数,每行按照“成绩:人数”的格式输出,按照人数降序输出。
样例
输入
10
19 18 17 20 21 28 30 45 48 51
输出
E:3 F:3 C:2 B:1 D:1 A:0
代码
#include<bits/stdc++.h>
using namespace std;
struct s{
char a;
int cnt;
}a[10];
bool cmp(s x,s y){
if(x.cnt!=y.cnt){
return x.cnt>y.cnt;}
return x.a<y.a;}
int main(){
int n;
cin>>n;
for(int i=0;i<6;i++){
a[i].a='A'+i;}
for(int i=0;i<n;i++){
int x;
cin>>x;
if(x<20) a[5].cnt++;
else if(x<30) a[4].cnt++;
else if(x<40) a[3].cnt++;
else if(x<50) a[2].cnt++;
else if(x<60) a[1].cnt++;
else a[0].cnt++;}
sort(a,a+6,cmp);
for(int i=0;i<6;i++){
cout<<a[i].a<<':'<<a[i].cnt<<endl;}
return 0;}