[CSP-S模拟测试]:开心的金明(贪心+模拟)
题目传送门(内部题117)
输入格式
第一行一个整数$k$,表示需要处理的月份数。
接下来的$k$行,每行$4$个整数,第$1+i$行分别为:$c_i,d_i,m_i,p_i$
接下来的$k-1$行,每行三个整数,其中第$1+k+i$行分别为:$e_i,R_i,E_i$。分别表示从第$i$月存到$i+1$月的数据。
输出格式
一行,包括一个整数。如果能够满足所有顾客的需求,输出最小成本。如果不能满足顾客需求,输出$-1$。
样例
样例输入1:
2
10 5 3 6
15 7 2 8
2 3 2
样例输出1:
170
样例输入2:
2
0 8 0 7
0 0 0 0
0 0 0
样例输出2:
-1
数据范围与提示
样例$1$解释:
在第一个样品测试用例中,第一个月,你可以购买$12$个单位的原材料,这需要花费$120$元,然后把其中的7个放入下个月的仓库,这需要花费$21$元。然后,你的公司可以生产$5$台电脑并销售,这需要$15$元。在第二个月,贵公司可以生产和销售$7$台,使用仓库中的原材料的电脑,需要$14$元。总成本为$170$元,证明是最优的。
数据范围:
对于$10\%$的数据,$k=2$;
对于$30\%$的数据,$k\leqslant 100$;
对于$50\%$的数据,$k\leqslant 1,000$;
对于$70\%$的数据,$k\leqslant 10,000$;
对于$100\%$的数据,$2\leqslant k\leqslant 50,000,0\leqslant c_i,d_i,m_i,p_i\leqslant 10^4,0\leqslant ei\leqslant 10^8,0\leqslant R_i,E_i\leqslant 10^4$。
题解
考虑贪心,最后剩余电脑数为$0$一定最优;购买的原材料数量和出售的电脑数一定相同。
因为原材料可以无限购买和存储,所以$c[i]=\min(c[i],c[i-1]+R[i-1])$。
那么考虑电脑,也可以用这样的方式处理;开一个$multiset$存储即可。
剩下的就都是模拟了。
时间复杂度:$\Theta(k\log\max(e[i]))$。
期望得分:$100$分。
实际得分:$100$分。
代码时刻
#include<bits/stdc++.h>
#define L(x) x<<1
#define R(x) x<<1|1
using namespace std;
struct rec{int c,d,m,p,e,R,E;}e[50010];
int n,size,lst;
multiset<pair<int,int>>s;
long long ans;
int main()
{
scanf("%d",&n);e[0].c=0x3f3f3f3f;
for(int i=1;i<=n;i++)scanf("%d%d%d%d",&e[i].c,&e[i].d,&e[i].m,&e[i].p);
for(int i=1;i<n;i++)scanf("%d%d%d",&e[i].e,&e[i].R,&e[i].E);
for(int i=1;i<=n;i++)e[i].c=min(e[i].c,e[i-1].c+e[i-1].R);
for(int i=1;i<=n;i++)e[i].m+=e[i].c;
for(int i=1;i<=n;i++)
{
s.insert(make_pair(e[i].m-lst,e[i].p));
size+=e[i].p;
while(e[i].d)
{
if(s.empty()){puts("-1");return 0;}
pair<int,int> x=*s.begin();
s.erase(s.begin());
size-=x.second;
if(e[i].d<x.second)
{
ans+=1LL*(x.first+lst)*e[i].d;
x.second-=e[i].d;e[i].d=0;
size+=x.second;
s.insert(x);
}
else
{
ans+=1LL*(x.first+lst)*x.second;
e[i].d-=x.second;
}
}
while(e[i].e<size)
{
pair<int,int> x=*--s.end();
s.erase(--s.end());
size-=x.second;
if(size<e[i].e)
{
x.second=e[i].e-size;
s.insert(x);
size+=x.second;
}
}
lst+=e[i].E;
}
printf("%lld",ans);
return 0;
}
rp++
[CSP-S模拟测试]:开心的金明(贪心+模拟)的更多相关文章
- codevs 1115 开心的金明--01背包
1115 开心的金明 2006年NOIP全国联赛普及组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 金明今天很开心,家里购 ...
- 洛谷 P1060 开心的金明
开心的金明 Problem Description: 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间他自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:"你的房间需要购买哪些 ...
- Luogu 1060 开心的金明 / NOIP 2006 (动态规划)
Luogu 1060 开心的金明 / NOIP 2006 (动态规划) Description 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间他自己专用的很宽敞的房间.更让他高兴的是,妈妈昨 ...
- 【洛谷p1060】开心的金明
(DP背包第一题,值得记录思路呀) 开心的金明[传送门] 洛谷算法标签: 01背包问题的思路分析见[总结]01背包问题 这道题显然是典型的01背包问题,首先我们显然可以由输入的第i个物体的价格v[i] ...
- P1060 开心的金明
P1060 开心的金明 题目描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间他自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要 ...
- P1060 开心的金明(洛谷,动态规划递推,01背包轻微变形题)
题目链接:P1060 开心的金明 基本思路: 基本上和01背包原题一样,不同点在于这里要的是最大重要度*价格总和,我们之前原题是 f[j]=max(f[j],f[j-v[i]]+p[i]); 那么这里 ...
- sicily 1342 开心的金明 (动规)
刷一下简单的背包问题 以下为代码: //1342. 开心的金明 #include <iostream> using namespace std; #define MAX(a,b) a> ...
- RQNOJ PID2 / 开心的金明
题目描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间他自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过N 元钱就行”.今 ...
- 开心的金明 NOIP 2006 普及组
题目描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间他自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:"你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过N元钱就 ...
随机推荐
- jQuery扁平化风格手风琴菜单
在线演示 本地下载
- Git复习(十三)之git revert用法及与git reset区别
git revert用法以及与git reset的区别 git revert用法 git revert 撤销 某次操作,此次操作之前和之后的commit和history都会保留,并且把这次撤销 作为一 ...
- O018、理解 Keystone 核心概念
参考https://www.cnblogs.com/CloudMan6/p/5365474.html 作为OpenStack的基础支持服务,Keystone做了下面几件事情: 1.管理 ...
- springboot(十九)-线程池的使用
我们常用ThreadPoolExecutor提供的线程池服务,springboot框架提供了@Async注解,帮助我们更方便的将业务逻辑提交到线程池中异步执行. 话不多说,编码开始: 1.创建spri ...
- 微信支付成功没有回调遇到的坑 onBridgeReady getBrandWCPayRequest wx.chooseWXPay
最近在调微信支付,遇到一个问题,就是支付成功回调不执行的. 遇到的问题就是 苹果手机 支付成功没有进到回调函数里,但是支付的时候,点击取消支付是可以进到回调函数里的. 安卓手机测试一切正常! ...
- nginx_rtmp
rtmp { server { listen ; chunk_size ; max_connections ; #音视频流上传和播放地址都是 rtmp://你的IP/live/streamName # ...
- 10 Zabbix4.4.1系统告警“Zabbix server is not running”
点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 Zabbix4.4.1系统告警“Zabbix server is not running” 第一步 ...
- Java 实现《编译原理》简单词法分析功能 - 程序解析
Java 实现<编译原理>简单词法分析功能 - 程序解析 简易词法分析功能 要求及功能 (1)读取一个 txt 程序文件(最后的 # 作为结束标志,不可省去) { int a, b; a ...
- java字符串函数用法汇总
替换字符串中的字符 例如有如下x的字符串 String x = "[kllkklk\kk\kllkk]"; 要将里面的"kk"替换为++,可以使用两种方法得到相 ...
- UVA - 1640 The Counting Problem (数位dp)
题意:统计l-r中每种数字出现的次数 很明显的数位dp问题,虽然有更简洁的做法但某人已经习惯了数位dp的风格所以还是选择扬长避短吧(说白了就是菜啊) 从高位向低位走,设状态$(u,lim,ze)$表示 ...