

新闻资讯
行业动态Java学生成绩统计程序需用Student类封装数据,HashMap分组聚合(如按班级或分数段),Comparator多条件排序,一次遍历完成多项统计,并用格式化输出清晰展示结果。
用Java实现学生成绩统计程序,核心在于合理使用集合(如ArrayList、HashMap)组织数据,并借助排序机制(自然排序、自定义Comparator)完成名次、分段统计等需求。关键不是堆砌功能,而是理清“谁存什么”“按什么排”“怎么算”三个逻辑层次。
别用Map或多个平行数组存姓名、成绩、班级——易错且难扩展。应定义清晰的Student类:
private String name;、private int score;、private String clazz;(班级)toString()方便调试输出Student实现Comparable,在compareTo()中比较score(注意降序用o2.score - o1.score)统计各班平均分、最高分,或统计90分以上人数,本质是“按条件分组 + 聚合计算”。HashMap最直接:
Map> classMap = new HashMap(); ,遍历所有学生,用classMap.computeIfAbsent(clazz, k -> new ArrayList()).add(student);
TreeMap存各段人数(键为段下限,值为计数)实际场景中,常需“按分数降序”“同分按姓名升序”“先按班级再按分数”,此时Comparable固定逻辑不够用,推荐匿名Comparator或方法引用:
立即学习“Java免费学习笔记(深入)”;
Collections.sort(students, Comparator.comparing(Student::getScore).reversed().thenComparing(Student::getName));
List单独调用sort(),不影响全局顺序students.stream().sorted(...).collect(Collectors.toList())
不必追求GUI,但输出需区分层级,便于验证结果:
String.format("%-2d %-8s %4d %6s", rank, s.getName(), s.getScore(), s.getClazz())
Scanner读取选择,增强可用性