0

0

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

花韻仙語

花韻仙語

发布时间:2026-01-26 23:12:02

|

992人浏览过

|

来源于php中文网

原创

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

本文讲解如何在java中实现“仅当申请人所有课程分数都严格大于指定阈值时,才将其姓名加入结果列表”的逻辑,重点纠正常见误区(如误将“任一课程达标”当作“全部课程达标”),并提供传统循环与stream api两种专业实现方式。

在实际开发中,一个典型误区是:遍历学生每门课程分数时,只要遇到一个高于阈值的分数就立即添加该学生姓名——这会导致只要有一门课达标就入选,而题目要求的是所有课程都必须严格高于阈值(即“全量达标”,而非“存在性达标”)。

❌ 错误逻辑分析

原始代码中:

if (courses.getScore() > scoreThreshold) {
  highScoringStudents.add(current.getKey()); // ⚠️ 只要一门课达标就加一次!重复添加、逻辑错误
}

该写法会在 Julie 的 5 门课中触发 5 次 add("Julie"),且 Paul 因第1门课(86 > 85)也被错误加入,完全违背题意。

✅ 正确解法一:布尔标记 + 提前退出(推荐用于教学与调试)

使用 boolean pass = true 标记当前学生是否“全员达标”,内层循环一旦发现任意一门课 ≤ 阈值,立刻设为 false 并 break,避免无效遍历:

List highScoringStudents = new LinkedList<>();
for (Map.Entry> entry : scoresByApplicantName.entrySet()) {
    boolean allAboveThreshold = true;
    for (CourseGrade grade : entry.getValue()) {
        if (grade.getScore() <= scoreThreshold) {
            allAboveThreshold = false;
            break; // 提前终止,提升性能
        }
    }
    if (allAboveThreshold) {
        highScoringStudents.add(entry.getKey());
    }
}
return highScoringStudents;

✅ 优势:逻辑清晰、易于理解与调试;时间复杂度最坏 O(N×M),但平均表现优异(常提前退出)。

QIMI奇觅
QIMI奇觅

美图推出的游戏行业广告AI制作与投放一体化平台

下载

✅ 正确解法二:Stream API 函数式实现(简洁优雅)

利用 allMatch() 精准表达“所有元素满足条件”的语义,配合 filter 和 map 实现链式处理:

import java.util.stream.Collectors;

return scoresByApplicantName.entrySet().stream()
    .filter(entry -> entry.getValue().stream()
        .allMatch(course -> course.getScore() > scoreThreshold))
    .map(Map.Entry::getKey)
    .collect(Collectors.toList());

✅ 优势:语义明确、无临时变量、符合现代Java风格;底层同样支持短路求值(allMatch 遇到第一个 false 即停)。

⚠️ 注意事项

  • > 而非 >=:题目明确要求“strictly greater”,必须用 > 判断;
  • 空列表安全:若某学生无任何课程(entry.getValue() 为空),allMatch 默认返回 true —— 若业务上需排除空记录,应额外增加 !entry.getValue().isEmpty() 判断;
  • 集合类型选择:返回类型为 List,LinkedList 或 ArrayList 均可;若后续高频随机访问,建议 ArrayList;本场景以插入为主,两者差异不大。

✅ 验证示例

对测试数据(阈值=85):

  • Julie:89,90,99,100,89 → 全 > 85 → ✅ 入选
  • Paul:86,80,76,80 → 含 80/76 ≤ 85 → ❌ 排除
  • Zoe:99,91,86,90,99,100 → 全 > 85 → ✅ 入选
    → 正确返回 ["Julie", "Zoe"](顺序无关,由 HashSet 断言保障)。

掌握“全量条件判断”的思维模式,是处理集合过滤类问题的关键能力。两种实现方式可根据团队技术与可读性需求灵活选用。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

463

2023.08.02

java中boolean的用法
java中boolean的用法

在Java中,boolean是一种基本数据类型,它只有两个可能的值:true和false。boolean类型经常用于条件测试,比如进行比较或者检查某个条件是否满足。想了解更多java中boolean的相关内容,可以阅读本专题下面的文章。

350

2023.11.13

java boolean类型
java boolean类型

本专题整合了java中boolean类型相关教程,阅读专题下面的文章了解更多详细内容。

29

2025.11.30

java中break的作用
java中break的作用

本专题整合了java中break的用法教程,阅读专题下面的文章了解更多详细内容。

118

2025.10.15

java break和continue
java break和continue

本专题整合了java break和continue的区别相关内容,阅读专题下面的文章了解更多详细内容。

258

2025.10.24

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

397

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

575

2023.08.10

golang map内存释放
golang map内存释放

本专题整合了golang map内存相关教程,阅读专题下面的文章了解更多相关内容。

75

2025.09.05

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

14

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3万人学习

C# 教程
C# 教程

共94课时 | 7.9万人学习

Java 教程
Java 教程

共578课时 | 52.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号