P3045 [USACO12FEB] Cow Coupons G (用堆实现反悔贪心)

news/2024/10/20 2:32:29

题解


题目链接

P3045 [USACO12FEB] Cow Coupons G

解题思路

反悔贪心
大体思路即为: 将所有 \(p_i\)\(c_i\) 分别存入两个小根堆中,每次取出下标未使用过的堆顶元素 \(p_i\)\(c_j\),并变成实际的应增加费用 \(p_i\)\(c_j + \Delta k\) (最小的 \(p_k - c_k\)) 进行比较,决定选择 \(i\) 还是 \(j\) . 具体的思路与证明可以看Luogu题解, 里面非常详细与全面.

重点代码部分就是

if (tc + delta.top() > tp) {    //相当于将 对i使用优惠卷实际上应该增加的费用 和 不对j使用优惠卷应该增加的费用 作比较m -= tp;P.pop();vis[i] = 1;}else {m -= tc + delta.top();delta.pop();C.pop();vis[j] = 1;delta.push(p[j] - c[j]);}

这里Luogu的大部分题解写的都是 移项后的 \(delta.top() > tp - tc\), 困扰了我非常久:为什么tp和tc明明对应的下标不一定一样,却可以直接相减.

时间复杂度与空间复杂度分析

由于堆的使用, 两个最大大小为n和一个大小为k的堆,时间与空间复杂度均为 \(O(nlogn)\) 左右.

完整代码

#include <bits/stdc++.h>#define int long longusing namespace std;using PII = pair<int, int>;signed main() {ios::sync_with_stdio(0), cin.tie(0);int n, k, m;cin >> n >> k >> m;priority_queue<PII, vector<PII>, greater<>> P, C;priority_queue<int, vector<int>, greater<>> delta;vector<int> p(n + 1), c(n + 1), vis(n + 1);for (int i = 1; i <= n; ++i) {cin >> p[i] >> c[i];P.push({p[i], i});C.push({c[i], i});}for (int i = 1; i <= k; ++i) delta.push(0);  //相当于给了k次无脑使用优惠卷的机会int ans = 0;while (P.size()) {auto [tp, i] = P.top();auto [tc, j] = C.top();if (vis[i]) {P.pop();continue;}if (vis[j]) {C.pop();continue;}if (tc + delta.top() > tp) {    //相当于将 对i使用优惠卷实际上应该增加的费用 和 不对j使用优惠卷应该增加的费用 作比较m -= tp;P.pop();vis[i] = 1;}else {m -= tc + delta.top();delta.pop();C.pop();vis[j] = 1;delta.push(p[j] - c[j]);}if (m >= 0) ans++;else break;}cout << ans << "\n";return 0;
}

AC提交记录

(https://www.luogu.com.cn/record/176544896)
image

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

Node.js安装及环境配置

1.下载nodejs https://nodejs.org/en/download直接下载安装包即可(什么fnm,nvm什么的fuck out,我就想装个nodeJs不想学什么包管理器的操作,需要多版本,我可以安装多个nodejs) 默认选项直接安装,不需要点任何配置 安装完毕后,建议在安装目录下,新建两个文件夹 node_cac…

我还没死

the Book of Genesis身边并没有朋友,以防那天死了所有人都不知道,所以弄一个这个,如果我活着,会以 \(\le 7d\) 的间隔重新发布,如果没有重新发布,可以尝试 qq 联系(2637322536),如果七天内没有回复,大概是死了,如果这篇博客被删除,说明我认为设立这篇博客的动机消失…

Codeforces Round 979 (Div. 2)题解记录

比赛链接:https://codeforces.com/contest/2030 A. A Gift From Orangutan 肯定最小值和最大值放前面最好,答案得解#include<iostream>#include<string.h>#include<map>#include<vector>#include<set>#include<unordered_set>#include&l…

AI工人操作行为流程规范识别系统

AI工人操作行为流程规范识别系统利用高清监控摄像头覆盖现场作业区域,AI工人操作行为流程规范识别系统通过图像识别和深度学习技术对作业人员的操作行为进行实时分析。AI工人操作行为流程规范识别系统能够准确识别工人的操作行为是否符合作业标准规定的流程和合规SOP,并根据设…

高级程序语言课第三次作业

2024高级语言程序设计:https://edu.cnblogs.com/campus/fzu/2024C 高级语言程序设计课程第三次个人作业:https://edu.cnblogs.com/campus/fzu/2024C/homework/13284 学号:102400115 姓名:洪育豪 作业内容:编写并运行书本第4章4.8编程练习题目中的第2题到第4题,第6题到第8题 编…

传送带下料口堵塞识别检测系统

传送带下料口堵塞识别检测系统利用AI视觉识别算法,传送带下料口堵塞识别检测系统通过现场监控摄像头对传送带的运输物料过程进行实时分析和识别。传送带下料口堵塞识别检测系统能够准确判断下料口是否出现堵塞现象,并及时抓拍有关图像进行记录。传送带下料口堵塞识别检测系统…

React/Vue 实现的前端应用, java/Go/Python 实现的后端应用,前后端分离的应用部署的最佳实践

前后端分离的应用(React 前端 + Java 后端)在部署过程中,需要考虑性能、扩展性、安全性、以及维护方便性等多个方面。下面我将详细介绍前后端分离应用的最佳实践,从架构设计、构建和打包、部署策略、CI/CD 集成、安全性措施等几个角度来描述。 微服务架构图示例壹.总体概述…

gradle配置代理

下载gradle项目 访问:https://start.spring.io/如上图所示,生成代码 配置代理服务器 买个国外的节点,使用 xshell 带代理方式连接,会暴露出 socks://localhost:1080建议开启 BBR 拥塞控制 # 要确保 linux 内核版本是4.9或更高,否则后面不用做了 uname -r # 加载 TCP BBR 模…