原题链接:蓝桥杯算法提高VIP-分数统计
解题思路:
使用5个数组记录5个分数段,使用五个整形记录五个分数段人数
参考代码:
#include<bits/stdc++.h>
using namespace std;
int main(){
int a, b, c, d, e;
int n;
cin >> n;
a = b = c = d = e = 0;
int A[101] = {0};
int B[90] = {0};
int C[80] = {0};
int D[70] = {0};
int E[60] = {0};
while( n--){
int score;
cin >> score;
if( score > 89){
A[score]++;
a++;
}else if( score > 79){
B[score]++;
b++;
}else if( score > 69){
C[score]++;
c++;
}else if( score > 59){
D[score]++;
d++;
}else{
E[score]++;
e++;
}
}
int most = a; //记录人数最多的分数段
if(most < b)
most = b;
if( most < c)
most = c;
if( most < d)
most = d;
if( most < e)
most = e;
cout << a << " " << b << " " << c << " " << d << " " << e << endl << most << endl;
int i;
if( most == a){
for( i = 100; i > 89; i--){
while( A[i]--) //同分数段不止有一人时继续输出
cout << i << " ";
}
}else if( most == b){
for( i = 89; i > 79; i--){
while( B[i]--)
cout << i << " ";
}
}else if( most == c){
for( i = 79; i > 69; i--){
while( C[i]--)
cout << i << " ";
}
}else if( most == d){
for( i = 69; i > 59; i--){
while( D[i]--)
cout << i << " ";
}
}else if( most == e){
for( i = 59; i > -1; i--){
while( E[i]--)
cout << i << " ";
}
}
return 0;
}0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复