1314. 仰卧起坐成绩统计

问题描述

四年级二班女同学在体育课上进行了一轮仰卧起坐测试。成绩计算表如下。

一分钟内做仰卧起坐的个数  成绩
   <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;}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值