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 5
3 1
4 8
8 3

Sample Output

TAK
2 3 1

Solution:

不难看出这是一个贪心问题,将打完能整体回血的的怪物和打完整体会掉血的分开。

1.因为打能回血的怪时无论消耗多少都能恢复,所以应该先打消耗最少的,到后面才有更大的生命值打最大的,打完第一部分时血量到达最大值,所以应该按消耗从小到大排序。

2.第二部分可以反向思考,将最终状态作为初始状态,那么回血就是掉血,掉血就是回血,因为第二个部分总体掉血,所以反过来总体回血,假设末状态血量为x,那么就让第一个部分结束时尽可能大,反向思考后就成为了第一个部分的问题,按照反向思考后掉血(就是正常情况下的回血)升序排列,反回来就是按照回血降序排列。

总结:

贪心算法在贪心策略满足无后效性时才能保证正确性。
某些贪心的正确性难以严格证明 ,这时可以考虑分部分讨论,逆向思考,枚举多种策略的办法做贪心。

证明贪心可以举反例、考虑极端情况或者类比论证。

转载于:https://www.cnblogs.com/Liuz8848/p/10332542.html

[BZOJ 3709] Bohater相关推荐

  1. bzoj 3709: [PA2014]Bohater

    3709: [PA2014]Bohater 链接 http://www.lydsy.com/JudgeOnline/problem.php?id=3709 题面 在一款电脑游戏中,你需要打败n只怪物( ...

  2. BZOJ 3709: [PA2014]Bohater 贪心

    时空隧道 分析: 这种题基本上都是贪心了- 我们考虑怎样安排才能使得自己不会死掉-QAQ-当然是生命值越大越好-所以为们应该贪心的先使自己的生命值增大再去减小生命值- 所以我们就得到了一个大概的贪心方 ...

  3. BZOJ.1558.[JSOI2009]等差数列(线段树 差分)

    BZOJ 洛谷 首先可以把原序列\(A_i\)转化成差分序列\(B_i\)去做. 这样对于区间加一个等差数列\((l,r,a_0,d)\),就可以转化为\(B_{l-1}\)+=\(a_0\),\(B ...

  4. S-T平面图中利用最短路求最小割(BZOJ 1001)

    BZOJ 1001: [BeiJing2006]狼抓兔子 最小割 题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1001 现在小朋友们最喜欢 ...

  5. BZOJ 1124: [POI2008]枪战Maf(构造 + 贪心)

    题意 有 \(n\) 个人,每个人手里有一把手枪.一开始所有人都选定一个人瞄准(有可能瞄准自己).然后他们按某个顺序开枪,且任意时刻只有一个人开枪. 因此,对于不同的开枪顺序,最后死的人也不同. 问最 ...

  6. BZOJ 2957楼房重建

    传送门 线段树 //Twenty #include<cstdio> #include<cstdlib> #include<iostream> #include< ...

  7. BZOJ.5249.[九省联考2018]iiidx(贪心 线段树)

    BZOJ LOJ 洛谷 \(d_i\)不同就不用说了,建出树来\(DFS\)一遍. 对于\(d_i\)不同的情况: Solution 1: xxy tql! 考虑如何把这些数依次填到树里. 首先对于已 ...

  8. bzoj 4871: [Shoi2017]摧毁“树状图”

    4871: [Shoi2017]摧毁"树状图" Time Limit: 25 Sec  Memory Limit: 512 MB Submit: 53  Solved: 9 [Su ...

  9. BZOJ 1592. Making the Grade(思维,数据结构优化DP,以及三个拓展问题)[Usaco2008 Feb]【BZOJ计划】

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 BZOJ简单题合集x 目录 BZOJ 1592. Making the Grade 拓展问题一 拓展问 ...

  10. BZOJ 1590.Secret Message 秘密信息(Trie树) [Usaco2008 Dec]【BZOJ计划】

    整理的算法模板合集: ACM模板 点我看算法全家桶系列!!! 实际上是一个全新的精炼模板整合计划 BZOJ简单题合集x Weblink https://hydro.ac/d/bzoj/p/1590 P ...

最新文章

  1. iOS:NSBundle的具体介绍
  2. 谈“80后”程序员为什么找不到工作? [转]
  3. 吴恩达机器学习 6.神经网络学习
  4. openresty 前端开发入门三之JSON篇
  5. 阿里云发布聆听平台 全球招募300位MVP
  6. H5的sessionStorage 和 localStorage
  7. 基于麻雀算法改进的随机森林分类算法 - 附代码
  8. 如何利用PS做文字拼接海报
  9. pythonlbp纹理提取_特征提取算法(1)——纹理特征提取算法LBP
  10. 使用google搜索自己在csdn写的博客
  11. C语言:数组排序(选择法排序)
  12. 终极指南 | 干了这篇收心文,从入门到精通手把手教你写出最牛白皮书!
  13. Compose系列 五 副作用 side-effect
  14. 斐讯n1盒子装网易音乐命令版
  15. 微信故障,算不算是小事?
  16. python无法打开excle_python – xlsxwriter模块无法正确打开/关闭Excel文件
  17. Allegro PCB Design GXL (legacy) - Merge Shapes(合并形状)
  18. 机器学习 | MATLAB实现MLP多层感知机newff参数设定(下)
  19. 吴恩达机器学习第二周编程题参考答案
  20. 人造大理石行业调研报告 - 市场现状分析与发展前景预测(2021-2027年)

热门文章

  1. flutter实战1:完成一个有侧边栏的主界面
  2. Azure Redis 缓存使用注意事项与排查问题文档整理
  3. java GC 参数
  4. springcloud 分布式配置中心 config server config client
  5. 避免在ASP.NET Core中使用服务定位器模式
  6. [LeetCode]41.First Missing Positive
  7. iPhone/iPad/iPod touch编程时版本区分
  8. 如何清除BIOS密码
  9. UpdatePanelAnimation
  10. PHP设计模式——抽象工厂