解题思路:

注意事项:

参考代码:

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.0分

3 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论