news 2026/4/18 14:42:09

GESP认证C++编程真题解析 | B3872 [GESP202309 五级] 巧夺大奖

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GESP认证C++编程真题解析 | B3872 [GESP202309 五级] 巧夺大奖

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总帖:GESP认证C++编程真题解析 | 汇总


【题目来源】

洛谷:[B3872 GESP202309 五级] 巧夺大奖 - 洛谷

【题目描述】

小明参加了一个巧夺大奖的游戏节目。主持人宣布了游戏规则:

  1. 游戏分为n nn个时间段,参加者每个时间段可以选择一个小游戏。
  2. 游戏中共有n nn个小游戏可供选择。
  3. 每个小游戏有规定的时限和奖励。对于第i ii个小游戏,参加者必须在第T i T_iTi个时间段结束前完成才能得到奖励R i R_iRi

小明发现,这些小游戏都很简单,不管选择哪个小游戏,他都能在一个时间段内完成。关键问题在于,如何安排每个时间段分别选择哪个小游戏,才能使得总奖励最高?

【输入】

输入第一行,包含一个正整数n nnn nn既是游戏时间段的个数,也是小游戏的个数。约定1 ≤ n ≤ 500 1\le n\le5001n500

输入第二行,包含n nn个正整数。第i ii个正整数为T i T_iTi,即第i ii个小游戏的完成期限。约定1 ≤ T i ≤ n 1\le T_i\le n1Tin

输入第三行,包含n nn个正整数。第i ii个正整数为R i R_iRi,即第i ii个小游戏的完成奖励。约定1 ≤ R i ≤ 1000 1\le R_i\le 10001Ri1000

【输出】

输出一行,包含一个正整数C CC,为最高可获得的奖励。

【输入样例】

7 4 2 4 3 1 4 6 70 60 50 40 30 20 10

【输出样例】

230

【算法标签】

《洛谷 B3872 巧夺大奖》 #贪心# #GESP# #2023#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=505;// 最大任务数// 任务结构体structNode{intr;// 任务收益intt;// 任务截止时间}a[N];intn;// 任务数量intans;// 最大总收益boolst[N];// 标记时间点是否被占用// 比较函数:按收益降序排序boolcmp(Node x,Node y){returnx.r>y.r;// 收益高的排前面}intmain(){// 输入任务数量cin>>n;// 输入每个任务的截止时间for(inti=1;i<=n;i++){cin>>a[i].t;}// 输入每个任务的收益for(inti=1;i<=n;i++){cin>>a[i].r;}// 按收益降序排序sort(a+1,a+n+1,cmp);// 贪心算法:为每个任务安排时间for(inti=1;i<=n;i++)// 按收益从高到低处理任务{// 从任务的截止时间向前寻找空闲时间点for(intj=a[i].t;j>=1;j--){if(!st[j])// 如果时间点j空闲{ans+=a[i].r;// 安排任务,累加收益st[j]=1;// 标记时间点被占用break;// 找到时间点,跳出内层循环}}// 如果没有找到合适的时间点,任务不被安排(收益为0)}// 输出最大总收益cout<<ans<<endl;return0;}

【运行结果】

7 4 2 4 3 1 4 6 70 60 50 40 30 20 10 230
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 17:56:10

5大极速优化技巧:让你的语音识别效率倍增

5大极速优化技巧&#xff1a;让你的语音识别效率倍增 【免费下载链接】whisper openai/whisper: 是一个用于实现语音识别和语音合成的 JavaScript 库。适合在需要进行语音识别和语音合成的网页中使用。特点是提供了一种简单、易用的 API&#xff0c;支持多种语音识别和语音合成…

作者头像 李华
网站建设 2026/4/18 10:07:27

并查集(Union-Find)套路详解

什么是并查集 并查集是一种用于处理不相交集合的数据结构&#xff0c;主要支持两种操作&#xff1a; Union&#xff08;合并&#xff09;&#xff1a;将两个集合合并为一个集合Find&#xff08;查找&#xff09;&#xff1a;判断某个元素属于哪个集合 并查集特别适合解决连通性…

作者头像 李华
网站建设 2026/4/17 23:00:17

Windows平台Erlang/OTP 26安装部署指南

Windows平台Erlang/OTP 26安装部署指南 【免费下载链接】Erlang26-windows安装包介绍 Erlang/OTP 26 Windows安装包为开发者提供了便捷的Erlang环境部署方案。Erlang是一种强大的并发编程语言&#xff0c;广泛用于构建高性能分布式和实时系统。此安装包兼容RabbitMQ 3.13.0&…

作者头像 李华
网站建设 2026/4/18 6:31:18

jQuery验证插件1.19.5版本重磅更新:多文件上传验证与国际邮箱支持

jQuery验证插件1.19.5版本重磅更新&#xff1a;多文件上传验证与国际邮箱支持 【免费下载链接】jquery-validation 项目地址: https://gitcode.com/gh_mirrors/jqu/jquery-validation jQuery验证插件作为前端开发中最受欢迎的表单验证工具之一&#xff0c;在最新发布的…

作者头像 李华
网站建设 2026/4/18 5:33:06

33、工作流中排队活动与事件驱动活动的创建与实现

工作流中排队活动与事件驱动活动的创建与实现 在工作流开发中,排队活动和事件驱动活动是非常重要的概念。它们能够帮助我们实现复杂的业务逻辑,提高工作流的灵活性和可扩展性。下面将详细介绍如何创建排队活动和事件驱动活动。 创建排队活动 首先,我们需要添加自定义运行…

作者头像 李华
网站建设 2026/4/18 6:28:28

专业指南:如何高效使用McgsPro组态软件实现工控系统配置

专业指南&#xff1a;如何高效使用McgsPro组态软件实现工控系统配置 【免费下载链接】McgsPro组态软件v3.2.3昆仑通态软件下载仓库 McgsPro组态软件v3.2.3是昆仑通态专为TPC1570Gi设计的最新版本&#xff0c;发布于2019年1月15日。该软件包含组态环境和运行环境&#xff0c;适用…

作者头像 李华