洛谷 题解 P3173 【[HAOI2009]巧克力】
本蒟蒻又双叒叕被爆踩辣!
又是一道经典的贪心题:
那么怎样切割该块巧克力,花费的代价最少呢?
Solution:
窝们考虑每个状态,有多少种选择方法?
是不是可以选择横着切或者竖着切,就这两种方法吧;
窝们再来考虑这两种方法的代价,
首先,如果窝们准备横着切,那么此次处理的代价就是当前这次的代价*(已经竖着切的数量 + 1),因为已经竖着切出了这么多次,所以代价就是这个(那个+1的原因是巧克力本来就有一块好不好,切一次不就有两块辣。。。)
ans += q.top() * s2;//那么当前的代价就是s2次乘单次代价
那么如果窝们现在准备竖着切,那么是不是同理就可以推出当前这次的代价*(已经横着切的数量 + 1),因为已经横着切出了这么多次,所以代价就是这个(那个+1的原因是巧克力本来就有一块好不好,切一次不就有两块辣。。。)
ans += qq.top() * s1;//那么当前的代价就是s1次乘单次代价
那么窝们已经知道了两种方案的代价辣,窝们接下来就是要找最优方案辣:
窝们每次都比较两种方案,看那种更优窝们就选哪种方案
因为窝们每次都选择当前最优,所以窝们也同时可以保证全局最优!
Code:
#include<bits/stdc++.h>
using namespace std;
#define Rep(x, a, b) for(int x = a; x <= b; ++ x)
priority_queue<int> q, qq;//优先队列可以维护序列单调性
//q表示横着切,qq表示竖着切
int n, m, x, s1 = 1, s2 = 1, ans;
//s1表示已经横着切了多少次辣
//s2表示已经竖着切了多少次辣
//ans就是答案辣
int main(){
scanf("%d%d", &n, &m);
Rep(i, 1, n - 1){//因为切成n*m块,所以横着切n - 1次
scanf("%d", &x);//读入每次代价
q.push(x);//压入优先队列,维护其单调性
}
Rep(i, 1, m - 1){//同理,竖着切m-1次
scanf("%d", &x);//读入每次代价
qq.push(x);//压入优先队列,维护其单调性
}
while(! q.empty() && ! qq.empty()){//只要一个优先队列空了就要退出,因为如果有一个空了,那么它的top就会返回空,然后就会死循环。。
//找当前是竖着切更优还是横着切更优
if(q.top() > qq.top()){//如果是横着切更优
ans += q.top() * s2;//那么当前的代价就是s2次乘单次代价
++ s1;//记得更新s1的值,多了一份
q.pop();//已经切完的就要弹出
}
else{
ans += qq.top() * s1;//那么当前的代价就是s1次乘单次代价
++ s2;//记得更新s2的值,多了一份
qq.pop();//已经切完的就要弹出
}
}
//因为弹出来后只要一个方向是空,那么就只能去另一个方向辣,下面就是找哪一个不是空的
while(! q.empty()){//如果可以横着切,(好像也只能横着切
ans += q.top() * s2;// 那么当前的代价就是s2次乘单次代价
q.pop();//已经切完的就要弹出
++ s1;//这里可加可不加辣,因为qq已经空了,s1就没用了
}
while(! qq.empty()){//如果可以竖着切,(好像也只能竖着切
ans += qq.top() * s1;//那么当前的代价就是s1次乘单次代价
qq.pop();//已经切完的就要弹出
++ s2;//同上辣
}
printf("%d", ans);//输出
return 0;
}
修改一下:下面放一个对新人友好一点代码,思路差不多,不过注释较少
#include<bits/stdc++.h>
using namespace std;
int n, m, ans, s1 = 1, s2 = 1;
#define maxn 20010
#define Rep(x, a, b) for(int x = a; x <= b; ++ x)
struct node{
int v, c;
}e[maxn];
bool cmp(node a, node b){
return a.v > b.v;
}
int main(){
scanf("%d%d", &n, &m);
Rep(i, 1, n - 1){//因为切成n*m块,所以横着切n - 1次
scanf("%d", &e[i].v);
e[i].c = 0;//把其标记为0
}
Rep(i, n, n + m - 2){//同理,竖着切m-1次
scanf("%d", &e[i].v);
e[i].c = 1;//把其标记为1
}
sort(e + 1, e + n + m - 1, cmp);
Rep(i, 1, n + m - 2){
if(e[i].c == 0){
ans += e[i].v * s2;
++ s1;
}
else{
ans += e[i].v * s1;
++ s2;
}
}
printf("%d", ans);
return 0;
}
Ps:请看懂再抄
洛谷 题解 P3173 【[HAOI2009]巧克力】的更多相关文章
- 洛谷——P3173 [HAOI2009]巧克力
P3173 [HAOI2009]巧克力 题目描述 有一块n*m的矩形巧克力,准备将它切成n*m块.巧克力上共有n-1条横线和m-1条竖线,你每次可以沿着其中的一条横线或竖线将巧克力切开,无论切割的长短 ...
- 洛谷 题解 UVA572 【油田 Oil Deposits】
这是我在洛谷上的第一篇题解!!!!!!!! 这个其实很简单的 我是一只卡在了结束条件这里所以一直听取WA声一片,详细解释代码里见 #include<iostream> #include&l ...
- 洛谷 题解 P1600 【天天爱跑步】 (NOIP2016)
必须得说,这是一道难题(尤其对于我这样普及组205分的蒟蒻) 提交结果(NOIP2016 天天爱跑步): OJ名 编号 题目 状态 分数 总时间 内存 代码 / 答案文件 提交者 提交时间 Libre ...
- 洛谷题解P4314CPU监控--线段树
题目链接 https://www.luogu.org/problemnew/show/P4314 https://www.lydsy.com/JudgeOnline/problem.php?id=30 ...
- 洛谷 P2983 [USACO10FEB]购买巧克力Chocolate Buying 题解
P2983 [USACO10FEB]购买巧克力Chocolate Buying 题目描述 Bessie and the herd love chocolate so Farmer John is bu ...
- 洛谷P2983 [USACO10FEB]购买巧克力Chocolate Buying
题目描述 Bessie and the herd love chocolate so Farmer John is buying them some. The Bovine Chocolate Sto ...
- 洛谷题解 CF777A 【Shell Game】
同步题解 题目翻译(可能有童鞋没读懂题面上的翻译) 给你三张牌0,1,2. 最初选一张,然后依次进行n次交换,交换规则为:中间一张和左边的一张,中间一张和右边一张,中间一张和左边一张...... 最后 ...
- 洛谷题解 CF807A 【Is it rated?】
同步题解 题目 好吧,来说说思路: 1.先读入啦~(≧▽≦)/~啦啦啦 2.判断a[i]赛前赛后是否同分数,如果分数不同,则输出,return 0 . 3.如果同分数,则判断a[i]赛前(或赛后)是否 ...
- 洛谷题解 P1138 【第k小整数】
蒟蒻发题解了 说明:此题我用的方法为桶排(我翻了翻有人用了桶排只不过很难看出来,可能有些重复的,这个题只是作为一个专门的桶排来讲解吧) (不会算抄袭吧 ‘QWaWQ’) 简单来说(会的人跳过就行): ...
随机推荐
- 奶牛邻居——treap+契比雪夫距离+并查集
题目描述 了解奶牛们的人都知道,奶牛喜欢成群结队.观察约翰的N(1≤N≤100000)只奶牛,你会发现她们已经结成了几个“群”. 每只奶牛在吃草的时候有一个独一无二的位置坐标Xi,Yi(l≤Xi,Yi ...
- VM安装CentOS系统
本篇文章主要介绍了VMware安装Centos7超详细过程(图文) 1.软硬件准备 软件:推荐使用VMwear,我用的是VMwear 12 镜像:CentOS7 ,如果没有镜像可以在官网下载 :htt ...
- html5 微信真机调试方法vConsole
html5 微信真机调试方法 vConsolehttps://blog.csdn.net/weixin_36934930/article/details/79870240
- 使用websocketpp进行websocket通信
websocketpp介绍 websocketpp是一个只有头文件的支持websocket协议的C++开源库,支持websocket客户端和服务器功能,网络传输模块基于boost::asio 提供 s ...
- Python 基础 三 反射
Python 基础 三 反射 今天我们先介绍一下反射这个概念,啥是反射?反射就是自己检测自己.在我们Python的面向对象中的反射是啥意思呢?就是通过字符串的形式操作对象相关的属性.python中的一 ...
- [深度学习][图像处理][毕设][笔记][安装环境][下载地址]安装VS2013、matconvnet、cuda、cudnn过程中产生的一些记录,2018.5.6号
最近半个多月,被cuda等软件折磨的死去活来,昨天下午,终于安装好了环境,趁着matlab正在,在线下载VOT2016数据集,3点睡眼惺忪被闹醒后,睡不着,爬上来写这份记录. 先记录一下自己电脑的基本 ...
- lqb 入门训练 序列求和 (PS:用长整数做数据的输入输出)
入门训练 序列求和 时间限制:1.0s 内存限制:256.0MB 问题描述 求1+2+3+...+n的值. 输入格式 输入包括一个整数n. 输出格式 输出一行,包括一个整数,表示1+2+3 ...
- 决策树(中)-集成学习、RF、AdaBoost、Boost Tree、GBDT
参考资料(要是对于本文的理解不够透彻,必须将以下博客认知阅读): 1. https://zhuanlan.zhihu.com/p/86263786 2.https://blog.csdn.net/li ...
- Kali Rolling 系统配置总结 (Updateing)
主系统Kali Linux确实好用,继<Kali~2018安装后的配置>之后,自己又全面详细的总结了关于Kali Linux系统安装后的配置,<Kali Rolling 系统配置总结 ...
- JavaScript中解析JSON --- json.js 、 json2.js 以及 json3.js的使用区别
JSON官方(http://www.json.org/)提供了一个json.js,json.js是JSON官方提供的在JavaScript中解析JSON的js包,json.js.json2.js.js ...