题解:Luogu_P3045 [USACO12FEB] Cow Coupons G

news/2025/2/7 8:26:55/文章来源:https://www.cnblogs.com/nueryim/p/18701986

题解:Luogu_P3045 [USACO12FEB] Cow Coupons G

Luogu_P3045 [USACO12FEB] Cow Coupons G
贪心

Solution

首先有个最初的的想法,将所有牛不用优惠券的价格扔进一个小根堆里,用优惠券的价格扔进一个小根堆,每次比较两个堆顶的价格,选花钱最少的。

看组数据:

3 2 6
5 1
3 1
4 2

按照我们的策略,会选 1、2 号牛,实际如果选 1、3 号牛使用优惠券,剩下的钱可以买下 2 号牛。

问题出在哪里?我们没能正确分配对哪头牛使用优惠券,不过好在这种贪心方法虽然不能保证买到的牛最多,但能保证选到的牛最后都会被买到。(自己讨论一下哪些情况会被选到,发现扔掉都是不优的)

本质的问题出在我们在分配优惠券时,没能考虑每张优惠券能省多少,导致有些优惠券省的钱太少了,买同样的牛,将一些优惠券分配给 \(p_i-c_i\) 更大的牛总价钱会更少。

于是我们再弄一个小根堆,用来存 \(k\) 张优惠券的省钱情况,如果有牛可以更省就把优惠券给新的牛用。

Code

计算细节看代码

//P3045#include <iostream>
#include <cstdio>
#include <map>
#include <queue>#define lld long long
#define pii pair <int, int>using namespace std;inline lld read()
{lld val = 0;bool si = 0;char ch = getchar();for (; !isdigit(ch); ch = getchar())si ^= ch == '-';for (;  isdigit(ch); ch = getchar())val = (val << 3) + (val << 1) + (ch ^ 48);return si ? - val : val;
}const int N = 50005;int n, k, p[N], c[N], ans;
lld m;
bool vis[N];priority_queue <pii, vector <pii>, greater <pii> > heap, heac;
priority_queue <int, vector <int>, greater <int> > cost;int main()
{n = read(), k = read(), m = read();for (int i = 1; i <= n; i ++){heap.push(make_pair(p[i] = read(), i));heac.push(make_pair(c[i] = read(), i));}for (int i = 1; i <= k; i ++)cost.push(0);while (!heap.empty() && !heac.empty()){pii nowp = heap.top();if (vis[nowp.second]){heap.pop();continue;}pii nowc = heac.top();if (vis[nowc.second]){heac.pop();continue;}if (nowp.first <= nowc.first + cost.top()){m -= nowp.first;vis[nowp.second] = 1;heap.pop();}else{m -= nowc.first + cost.top();vis[nowc.second] = 1;heac.pop();cost.pop();cost.push(p[nowc.second] - c[nowc.second]);}if (m < 0) break;ans ++;}printf("%d\n", ans);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/879923.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ZW3D二次开发_入门_Action与Ribbon菜单定制--转自 知乎 捣蛋龙

ZW3D二次开发_入门_Action与Ribbon菜单定制捣蛋龙 ​关注他5 人赞同了该文章​ 目录收起ZW3D二开入门目录 - 知乎 (zhihu.com)最新测试环境:2025 SP前言定制Ribbon菜单1.新建工作区2.定义"行为"3.定义自定义Ribbon文件4.编写策略文件5.编写引导程序6.多环境差异化策…

day4

简单图论与构造 A 考虑把权值为 2 的点看作给权值为 1 的点加一, 所以整个问题被拆成了两个部分:构造树和给节点加一 事实上,在第一部分时我们将树构造的尽量平衡是有好处,这个结论在第二个步骤中会得到证明 构造: Process DFS(father,ch,u,size):if size==0 then returnso…

Omnissa Horizon Windows OS Optimization Tool 2412 - Windows 系统映像优化工具

Omnissa Horizon Windows OS Optimization Tool 2412 - Windows 系统映像优化工具Omnissa Horizon Windows OS Optimization Tool 2412 - Windows 系统映像优化工具 Optimizing Images Using Omnissa Horizon Windows OS Optimization Tool 请访问原文链接:https://sysin.org/…

BOM最全基础信息:标准件、通用件、替换件、必选件

在生产制造领域,物料清单(BOM)是产品设计、生产计划和供应链管理的核心基础。本文系统梳理了BOM中各类零部件的分类方法,供大家参考。在生产制造的复杂领域中,我们会与各式各样的产品组成部分打交道。清晰、准确地对它们进行分类,并实施有效的管理,对于提升生产效率、保…

人工智能辅助芯片设计

芯片设计:一个近乎无限的问题空间 设计复杂性呈指数级增长 设计复杂性的含义 一连串棘手的问题 贯穿整个流程优化 HDL生成研究 使用GCN加速设计评估 人工智能辅助验证 参考文献链接https://www.hc2024.hotchips.org/assets/program/tutorials/3-HC24.synopsys.SteliosDiaman…

应用随机过程 | 期末 cheat sheet

出分后发布笔记……这篇博客汇总了「应用随机过程」2018 - 2022 的期末试题,并根据题型分类总结。 本站相关博客:应用随机过程 | 期末知识点总结特别鸣谢:知乎 | 九一居士 |《应用随机过程》课程笔记系列目录1 马尔可夫链计算题2 常返的马尔可夫链3 连续时间参数的马尔可夫链…

推荐《AI芯片开发核心技术详解》、《智能汽车传感器:原理设计应用》、《TVM编译器原理与实践》、《LLVM编译器原理与实践》4本书,非常感谢

4本书推荐《AI芯片开发核心技术详解》、《智能汽车传感器:原理设计应用》、《TVM编译器原理与实践》、《LLVM编译器原理与实践》由清华大学出版社资深编辑赵佳霓老师策划编辑的新书《AI芯片开发核心技术详解》已经出版,京东、淘宝天猫、当当等网上,相应陆陆续续可以购买。该…

OpenVX基本原理与历史

OpenVX基本原理 2.1 引言 2.1.1 摘要 OpenVX 是一个低级编程框架域,用于支持软件开发人员,可高效访问计算机视觉硬件加速功能和性能的可移植性。OpenVX 旨在支持现代硬件架构,例如,移动和嵌入式 SoC 以及桌面系统。其中许多系统是并行和异构的:多个处理器类型包括多核 CPU…

L4D2自制角色Mod - HUI篇

如何以相对简易的思路自制求生之路2求生者头像Mod本文是笔者尝试制作 求生之路2 角色 Mod 的过程中编写的笔记,笔者的背景是有基础的计算机知识和图像处理软件的使用经验,相信大多数读者朋友都有同样的水平。本文面向希望能快速简单地自定义游戏内角色图像/模型,但对更深层次…

使用Netty与前端请求进行交互实现实时通讯

引言因为不满足与一般的SpringBoot CRUD开发(太无聊了)所以去学一下网络编程,第一站就是通过B站老罗的EasyChat项目了解到了Netty这个网络框架,在学习这个项目之前也是去学习了一下Netty框架的使用以及相关的原理知识所以是有一定了解的,但是只是一味的学习不去实践总感觉是空中…

如何使用 Filebeat 8 连接 Easysearch

在日志场景,还是有很多小伙伴在使用 Filebeat 采集日志的。今天我来实战下使用 Filebeat 8 连接 Easysearch 。本次使用 Easysearch-1.9.0 版本和 Filebeat-8.17.0 版本做演示,也适用 Filebeat-oss-8.17.0 版本。 Easysearch 不开启兼容参数的情况 Easysearch 默认情况下未开…