贝利信息

如何筛选所有课程成绩均严格高于阈值的申请者姓名

日期:2026-01-26 00:00 / 作者:霞舞

本文讲解如何正确实现一个java方法,从学生姓名到成绩列表的映射中,筛选出**所有课程分数均严格大于给定阈值**的学生姓名列表,重点纠正常见的逻辑错误(如误判为“任一课程达标”而非“全部课程达标”)。

在原始代码中,核心逻辑缺陷在于:内层循环一旦发现某个课程分数高于阈值,就立即添加学生姓名——这导致只要学生有一门课达标就会被计入结果,而题目要求的是所有课程都必须严格高于阈值(即“全科高分”学生)。

✅ 正确逻辑:全员达标判定

需为每位申请人维护一个布尔标志(如 allAboveThreshold),初始设为 true;遍历其所有课程成绩,只要遇到一门 ≤ 阈值的成绩,立即将标志置为 false 并提前退出循环;仅当遍历结束时标志仍为 true,才将该学生姓名加入结果列表。

以下是修正后的传统迭代写法:

public static List highScoringStudents(
    Map> scoresByApplicantName, 
    int scoreThreshold) {

    List result = new LinkedList<>();

    for (Map.Entry> entry : scoresByApplicantName.entrySet()) {
        boolean allAbove = true;
        for (CourseGrade grade : entry.getValue()) {
            if (grade.getScore() <= scoreThreshold) {
                allAbove = false;
                break; // 提前终止,提升效率
            }
        }
        if (allAbove) {
            result.add(entry.getKey());
        }
    }
    return result;
}

? 更优雅的函数式写法(推荐)

利用 Java 8 Stream API 可

以用一行清晰表达语义:“过滤出所有课程成绩均满足 > threshold 的条目,再提取姓名”:

import java.util.stream.Collectors;

public static List highScoringStudents(
    Map> scoresByApplicantName, 
    int scoreThreshold) {

    return scoresByApplicantName.entrySet().stream()
        .filter(entry -> entry.getValue().stream()
            .allMatch(grade -> grade.getScore() > scoreThreshold))
        .map(Map.Entry::getKey)
        .collect(Collectors.toList());
}
✅ allMatch() 是关键:它要求流中每个元素都满足谓词条件,完美对应“所有课程均高于阈值”的业务语义。

⚠️ 注意事项

综上,判断“全科达标”不是累加满足条件的个体,而是对每个个体做全量验证。掌握 allMatch 的语义与布尔标记的控制流程,是解决此类“全集约束”问题的关键。