[BZOJ 3709] Bohater
Description
在一款电脑游戏中,你需要打败n只怪物(从1到n编号)。为了打败第i只怪物,你需要消耗d[i]点生命值,但怪物死后会掉落血药,使你恢复a[i]点生命值。任何时候你的生命值都不能降到0(或0以下)。请问是否存在一种打怪顺序,使得你可以打完这n只怪物而不死掉
Input
第一行两个整数n,z(1<=n,z<=100000),分别表示怪物的数量和你的初始生命值。
接下来n行,每行两个整数d[i],a[i](0<=d[i],a[i]<=100000)
Output
第一行为TAK(是)或NIE(否),表示是否存在这样的顺序。
如果第一行为TAK,则第二行为空格隔开的1~n的排列,表示合法的顺序。如果答案有很多,你可以输出其中任意一个。
Sample Input
3 1
4 8
8 3
Sample Output
2 3 1
Solution:
不难看出这是一个贪心问题,将打完能整体回血的的怪物和打完整体会掉血的分开。
1.因为打能回血的怪时无论消耗多少都能恢复,所以应该先打消耗最少的,到后面才有更大的生命值打最大的,打完第一部分时血量到达最大值,所以应该按消耗从小到大排序。
2.第二部分可以反向思考,将最终状态作为初始状态,那么回血就是掉血,掉血就是回血,因为第二个部分总体掉血,所以反过来总体回血,假设末状态血量为x,那么就让第一个部分结束时尽可能大,反向思考后就成为了第一个部分的问题,按照反向思考后掉血(就是正常情况下的回血)升序排列,反回来就是按照回血降序排列。
总结:
贪心算法在贪心策略满足无后效性时才能保证正确性。
某些贪心的正确性难以严格证明 ,这时可以考虑分部分讨论,逆向思考,枚举多种策略的办法做贪心。
证明贪心可以举反例、考虑极端情况或者类比论证。
转载于:https://www.cnblogs.com/Liuz8848/p/10332542.html
[BZOJ 3709] Bohater相关推荐
- bzoj 3709: [PA2014]Bohater
3709: [PA2014]Bohater 链接 http://www.lydsy.com/JudgeOnline/problem.php?id=3709 题面 在一款电脑游戏中,你需要打败n只怪物( ...
- BZOJ 3709: [PA2014]Bohater 贪心
时空隧道 分析: 这种题基本上都是贪心了- 我们考虑怎样安排才能使得自己不会死掉-QAQ-当然是生命值越大越好-所以为们应该贪心的先使自己的生命值增大再去减小生命值- 所以我们就得到了一个大概的贪心方 ...
- BZOJ.1558.[JSOI2009]等差数列(线段树 差分)
BZOJ 洛谷 首先可以把原序列\(A_i\)转化成差分序列\(B_i\)去做. 这样对于区间加一个等差数列\((l,r,a_0,d)\),就可以转化为\(B_{l-1}\)+=\(a_0\),\(B ...
- S-T平面图中利用最短路求最小割(BZOJ 1001)
BZOJ 1001: [BeiJing2006]狼抓兔子 最小割 题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1001 现在小朋友们最喜欢 ...
- BZOJ 1124: [POI2008]枪战Maf(构造 + 贪心)
题意 有 \(n\) 个人,每个人手里有一把手枪.一开始所有人都选定一个人瞄准(有可能瞄准自己).然后他们按某个顺序开枪,且任意时刻只有一个人开枪. 因此,对于不同的开枪顺序,最后死的人也不同. 问最 ...
- BZOJ 2957楼房重建
传送门 线段树 //Twenty #include<cstdio> #include<cstdlib> #include<iostream> #include< ...
- BZOJ.5249.[九省联考2018]iiidx(贪心 线段树)
BZOJ LOJ 洛谷 \(d_i\)不同就不用说了,建出树来\(DFS\)一遍. 对于\(d_i\)不同的情况: Solution 1: xxy tql! 考虑如何把这些数依次填到树里. 首先对于已 ...
- bzoj 4871: [Shoi2017]摧毁“树状图”
4871: [Shoi2017]摧毁"树状图" Time Limit: 25 Sec Memory Limit: 512 MB Submit: 53 Solved: 9 [Su ...
- BZOJ 1592. Making the Grade(思维,数据结构优化DP,以及三个拓展问题)[Usaco2008 Feb]【BZOJ计划】
整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 BZOJ简单题合集x 目录 BZOJ 1592. Making the Grade 拓展问题一 拓展问 ...
- BZOJ 1590.Secret Message 秘密信息(Trie树) [Usaco2008 Dec]【BZOJ计划】
整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 BZOJ简单题合集x Weblink https://hydro.ac/d/bzoj/p/1590 P ...
最新文章
- iOS:NSBundle的具体介绍
- 谈“80后”程序员为什么找不到工作? [转]
- 吴恩达机器学习 6.神经网络学习
- openresty 前端开发入门三之JSON篇
- 阿里云发布聆听平台 全球招募300位MVP
- H5的sessionStorage 和 localStorage
- 基于麻雀算法改进的随机森林分类算法 - 附代码
- 如何利用PS做文字拼接海报
- pythonlbp纹理提取_特征提取算法(1)——纹理特征提取算法LBP
- 使用google搜索自己在csdn写的博客
- C语言:数组排序(选择法排序)
- 终极指南 | 干了这篇收心文,从入门到精通手把手教你写出最牛白皮书!
- Compose系列 五 副作用 side-effect
- 斐讯n1盒子装网易音乐命令版
- 微信故障,算不算是小事?
- python无法打开excle_python – xlsxwriter模块无法正确打开/关闭Excel文件
- Allegro PCB Design GXL (legacy) - Merge Shapes(合并形状)
- 机器学习 | MATLAB实现MLP多层感知机newff参数设定(下)
- 吴恩达机器学习第二周编程题参考答案
- 人造大理石行业调研报告 - 市场现状分析与发展前景预测(2021-2027年)