原题链接:蓝桥杯算法提高VIP-分数统计
解题思路:
注意事项:
参考代码:
import java.util.Scanner;
import java.util.Arrays;
public class 分数统计 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int a[] = new int[n];
int A = 0;int B = 0;int C = 0;int D = 0;int E = 0;
//创建各个等级的字符串,用于装各个等级的分数,为第三问做准备
String A1="",B1="",C1="",D1="",E1="";
for (int i=0;i<n;i++){
a[i] = sc.nextInt();
}
//先把输入的数进行排序
Arrays.sort(a);
//第一问:每个数/10,然后分配到各个等级的人数加1;
//for循环采用降序,为第三问做准备,因为先前数组排序是从小到大,答案输出要从大到小
for (int i=a.length-1;i>=0;i--){
switch (a[i]/10){
case 10:
case 9: A++; A1 = A1 + a[i] + " "; break;
case 8: B++; B1 = B1 + a[i] + " "; break;
case 7: C++; C1 = C1 + a[i] + " "; break;
case 6: D++; D1 = D1 + a[i] + " "; break;
default: E++; E1 = E1 + a[i] + " ";
}
}
//进行第一问的输出
System.out.printf("%d %d %d %d %d",A,B,C,D,E);
//创建一个数组用于对各个等级的人数进行比较
int count[] = {A,B,C,D,E};
int max = 0;
for (int i=0;i<count.length;i++){
if (count[i]>max){
max = count[i];
}
}
//输出第二问
System.out.println("\n" + max);
//输出第三问
if(max==A) System.out.print(A1);
if(max==B) System.out.print(B1);
if(max==C) System.out.print(C1);
if(max==D) System.out.print(D1);
if(max==E) System.out.print(E1);
}
}0.0分
3 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复