1314. 仰卧起坐成绩统计
问题描述
四年级二班女同学在体育课上进行了一轮仰卧起坐测试。成绩计算表如下。
一分钟内做仰卧起坐的个数 成绩
<20个 F
20~29个 E
30~39个 D
40~49个 C
50~59个 B
>=60个 A
请从键盘读入 n 位同学的在一分钟内做仰卧起坐的数量,计算出每个成绩区间的人数,按照人数降序排序,如果有多个成绩区间人数一样多,那么先输出成绩较好的区间。
输入 复制
第一行是一个整数 n 代表同学的人数( n≤100 );
第二行是 n 个同学一分钟完成仰卧起坐的数量。
输出 复制
输出 6 行为 6个成绩区间的人数,每行按照“成绩:人数”的格式输出,按照人数降序输出。
#include<bits/stdc++.h>
using namespace std;
struct stu{
char a;
int cnt;
}a[10];
bool cmp(stu x,stu 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;
cout<<endl;
}
return 0;
}
原文地址:https://blog.csdn.net/jht0105/article/details/135998672
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!