原题链接:蓝桥杯算法提高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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复