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;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值