【C++贪心】P8769 [蓝桥杯 2021 国 C] 巧克力|普及+

【C++贪心】P8769 [蓝桥杯 2021 国 C] 巧克力|普及+

本文涉及知识点

C++贪心

[蓝桥杯 2021 国 C] 巧克力

题目描述

小蓝很喜欢吃巧克力,他每天都要吃一块巧克力。

一天小蓝到超市想买一些巧克力。超市的货架上有很多种巧克力,每种巧克力有自己的价格、数量和剩余的保质期天数,小蓝只吃没过保质期的巧克力,请问小蓝最少花多少钱能买到让自己吃 x x x 天的巧克力。

输入格式

输入的第一行包含两个整数 x x x, n n n,分别表示需要吃巧克力的天数和巧克力的种类数。

接下来 n n n 行描述货架上的巧克力,其中第 i i i 行包含三个整数 a i a_i ai​, b i b_i bi​, c i c_i ci​,表示第 i i i 种巧克力的单价为 a i a_i ai​,保质期还剩 b i b_i bi​ 天(从现在开始的 b i b_i bi​ 天可以吃),数量为 c i c_i ci​。

输出格式

输出一个整数表示小蓝的最小花费。如果不存在让小蓝吃 x x x 天的购买方案,输出 − 1 −1 −1。

样例 #1

样例输入 #1

10 3 1 6 5 2 7 3 3 10 10 

样例输出 #1

18 

提示

【样例说明】

一种最佳的方案是第 1 1 1 种买 5 5 5 块,第 2 2 2 种买 2 2 2 块,第 3 3 3 种买 3 3 3 块。前 5 5 5 天吃第 1 1 1 种,第 6 6 6、 7 7 7 天吃第 2 2 2 种,第 8 8 8 至 10 10 10 天吃第 3 3 3 种。

【评测用例规模与约定】

对于 30 % 30\% 30% 的评测用例, n , x ≤ 1000 n,x \le 1000 n,x≤1000。

对于所有评测用例, 1 ≤ n , x ≤ 1 0 5 1\le n,x\le 10^5 1≤n,x≤105, 1 ≤ a i , b i , c i ≤ 1 0 9 1 ≤ a_i,b_i ,c_i\le10^9 1≤ai​,bi​,ci​≤109。

蓝桥杯 2021 国赛 C 组 I 题。

贪心

如果价格低的和价格高的,竞争同一天。淘汰价格高的。如果两个都能保留或都不能保留,结果一样。如果保留一个,显然保留价格低的合适。
按价格排序。
有序映射记录需要巧克了的天数。初始:1到x。
依次枚举各巧克力。
如果剩余数量为0,处理其它巧克力。
如果s中存在小于等于保质期的数字。将此巧克力分配一块到保质期内最后一天。如果没有,处理下一个巧克力。
如果最终s非空,返回-1。否则返回分配的巧克力之和。

2025年11月19

第x天吃一块保质期x的巧克力。
第x-1天吃保质期 ≥ x − 1 \ge x-1 ≥x−1的巧克力
⋮ \vdots ⋮
第1天吃保质期 ≥ 1 \ge 1 ≥1的巧克力。
第i天小根堆记录保质期 ≥ i \ge i ≥i的巧克力的价格和数量。

代码

核心代码

#include<iostream>#include<sstream>#include<vector>#include<map>#include<unordered_map>#include<set>#include<unordered_set>#include<string>#include<algorithm>#include<functional>#include<queue>#include<stack>#include<iomanip>#include<numeric>#include<math.h>#include<climits>#include<assert.h>#include<bitset>usingnamespace std;template<classT=int> vector<T>Read(int n,constchar* pFormat ="%d"){ vector<T> ret; T d ;while(n--){scanf(pFormat,&d); ret.emplace_back(d);}return ret;}template<classT=int> vector<T>Read(constchar* pFormat ="%d"){int n;scanf("%d",&n); vector<T> ret; T d;while(n--){scanf(pFormat,&d); ret.emplace_back(d);}return ret;} string ReadChar(int n){ string str;char ch;while(n--){do{scanf("%c",&ch);}while(('\n'== ch)); str += ch;}return str;}classSolution{public:longlongDo(int x, vector<int>& a, vector<int>& b, vector<int>& c){constint N = a.size(); vector<int>inxs(N);iota(inxs.begin(), inxs.end(),0);sort(inxs.begin(), inxs.end(),[&](int i1,int i2){return a[i1]< a[i2];}); set<int> need;for(int i =1; i <= x; i++){ need.emplace(i);}longlong ans =0;for(int i : inxs){for(int cnt =0; cnt < c[i]; cnt++){auto it = need.upper_bound(b[i]);if(need.begin()== it){break;}--it; need.erase(it); ans += a[i];if(need.empty()){return ans;}}}return-1;}};intmain(){#ifdef_DEBUGfreopen("a.in","r",stdin);#endif// DEBUGint x,n;scanf("%d%d",&x,&n); vector<int> a, b, c;int t1, t2, t3;for(int i =0; i < n; i++){scanf("%d%d%d",&t1,&t2,&t3); a.emplace_back(t1); b.emplace_back(t2); c.emplace_back(t3);}auto res =Solution().Do(x,a, b, c); cout << res << std::endl;return0;}

单元测试

int x; vector<int> a, b, c;TEST_METHOD(TestMethod11){ x =10, a ={1,2,3}, b ={6,7,10}, c ={5,3,10};auto res =Solution().Do(x, a, b, c);AssertEx(18LL, res);}TEST_METHOD(TestMethod12){ x =10, a ={1}, b ={100}, c ={9};auto res =Solution().Do(x, a, b, c);AssertEx(-1LL, res);}TEST_METHOD(TestMethod13){ x =10, a ={1}, b ={9}, c ={10};auto res =Solution().Do(x, a, b, c);AssertEx(-1LL, res);}

扩展阅读

我想对大家说的话
工作中遇到的问题,可以按类别查阅鄙人的算法文章,请点击《算法与数据汇总》。
学习算法:按章节学习《喜缺全书算法册》,大量的题目和测试用例,打包下载。重视操作
有效学习:明确的目标 及时的反馈 拉伸区(难度合适) 专注
闻缺陷则喜(喜缺)是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。
如果程序是一条龙,那算法就是他的是睛
失败+反思=成功 成功+反思=成功

视频课程

先学简单的课程,请移步ZEEKLOG学院,听白银讲师(也就是鄙人)的讲解。
https://edu.ZEEKLOG.net/course/detail/38771
如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.ZEEKLOG.net/lecturer/6176

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17
如无特殊说明,本算法用**C++**实现。

Read more

MCP 教程:将 Figma 设计稿转化为前端代码

📋 MCP:将 Figma 设计稿转化为前端代码 🎯 概述 还在手动从设计稿提取样式、编写基础代码?试试 Trae IDE 的模型上下文协议(MCP)功能吧。通过使用 MCP Server - Figma AI Bridge,自动将你的 Figma 设计稿转换为整洁的前端代码,并生成相应的网页。简单高效,无需复杂配置,跟随文中的步骤操作,即可体验智能化的设计交付。让我们开始吧! 🚀 效果展示 使用 Trae IDE 的 Figma AI Bridge MCP Server 将设计稿转换为前端代码的效果展示: * 设计稿到代码的自动转换: 无需手动编写 HTML、CSS 代码 * 响应式布局: 自动生成适配不同屏幕尺寸的响应式代码 * 组件化结构: 智能识别设计中的组件,生成可复用的组件代码

By Ne0inhk

Flutter 三方库 serial 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、稳定的 Web 串口通信与工业硬软连接实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 serial 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、稳定的 Web 串口通信与工业硬软连接实战 在鸿蒙(OpenHarmony)系统的工业平板、手持 PDA 及桌面协同场景中,如何通过 Web 容器直接操控外部硬件设备(如扫码枪、打印机、传感器)?serial 做为一个优秀的 window.navigator.serial API 的 Flutter 封装库,为鸿蒙开发者提供了跨平台的硬件底座。本文将深入探讨其在鸿蒙生态中的适配要点。 前言 什么是 Web Serial?它允许鸿蒙应用内的 Web 组件直接请求访问用户的串行设备。在 Flutter for OpenHarmony 的实际开发中,serial

By Ne0inhk

告别数据线!用filebrowser在安卓手机建Web文件服务器(Termux实战)

告别数据线!用filebrowser在安卓手机建Web文件服务器(Termux实战) 你是否也厌倦了每次在电脑和手机之间传输文件,都要翻箱倒柜找数据线,或者忍受第三方App缓慢的传输速度和恼人的广告?对于开发者、摄影师、内容创作者,或者仅仅是喜欢折腾的数码爱好者来说,一个随时可访问、完全由自己掌控的移动文件中心,其价值远超想象。 今天,我们就来深入探讨一个将你手中安卓手机瞬间变为强大局域网文件服务器的方案。核心工具是 filebrowser,一个轻量、高效、功能全面的开源Web文件管理器。我们将它部署在安卓上的Linux环境——Termux 中。这不仅仅是安装一个软件,更是构建一套完整的、可扩展的私人文件管理生态。我们将超越基础的安装步骤,深入对比它在移动端的独特优势,详解如何从内网穿透到外网访问,并配置精细的多用户权限,让你彻底摆脱物理媒介的束缚,享受无线文件管理的自由与高效。 1. 为什么是Termux + filebrowser?移动端文件服务器的黄金组合 在移动设备上搭建服务,我们面临的核心挑战是资源受限(CPU、内存、电池)和系统环境特殊(非标准Linux)。因此,

By Ne0inhk

OpenClaw Web Search 完全指南(2026年3月最新)

OpenClaw Web Search 完全指南(2026年3月最新) 本文详细介绍 OpenClaw 内置 web_search 工具的 5 个官方搜索渠道,以及 Tavily 技能的使用方法。帮助你选择最适合的免费/付费方案。 目录 * OpenClaw 搜索功能概述 * 5 个官方搜索渠道详解 * 1. Brave Search API * 2. Google Gemini * 3. Grok (xAI) * 4. Kimi (Moonshot) * 5. Perplexity * 免费额度对比表 * 推荐配置方案 * Tavily Web Search 技能 * 配置步骤详解 * 常见问题 OpenClaw 搜索功能概述 OpenClaw 提供两种搜索能力:

By Ne0inhk