题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3709

题意:

  在一款电脑游戏中,你需要打败n只怪物(从1到n编号)。

  为了打败第i只怪物,你需要消耗atk[i]点生命值,但怪物死后会掉落血药,使你恢复rec[i]点生命值。

  任何时候你的生命值都不能降到0(或0以下)。

  请问是否存在一种打怪顺序,使得你可以打完这n只怪物而不死掉。

题解:

  怪物总共分两种,一种是打完能回血的,一种是打完会掉血的。

  显然,先打能回血的,再打能掉血的。

  分别考虑两种怪:

    (1)能回血的:

      显然,先打atk小的怪物。按atk升序排列。

    (2)会掉血的:

      最后打完所有怪之后的血量end是一定的。

      那么将这个过程反过来考虑:初始血量为end,每打一个怪物掉rec[i]的血,然后回atk[i]的血。

      所以按照rec降序排列。

  最后模拟一遍能不能打完就行了。

AC Code:

  1. #include <iostream>
  2. #include <stdio.h>
  3. #include <string.h>
  4. #include <algorithm>
  5. #define MAX_N 100005
  6.  
  7. using namespace std;
  8.  
  9. struct Mons
  10. {
  11. int atk;
  12. int rec;
  13. int idx;
  14. Mons(int _atk,int _rec,int _idx)
  15. {
  16. atk=_atk;
  17. rec=_rec;
  18. idx=_idx;
  19. }
  20. Mons(){}
  21. friend bool operator < (const Mons &a,const Mons &b)
  22. {
  23. if(a.rec-a.atk>= && b.rec-b.atk>=) return a.atk<b.atk;
  24. else if(a.rec-a.atk< && b.rec-b.atk<)return a.rec>b.rec;
  25. return a.rec-a.atk>b.rec-b.atk;
  26. }
  27. };
  28.  
  29. int n;
  30. long long hp;
  31. bool failed=false;
  32. Mons mons[MAX_N];
  33.  
  34. void read()
  35. {
  36. cin>>n>>hp;
  37. for(int i=;i<=n;i++)
  38. {
  39. cin>>mons[i].atk>>mons[i].rec;
  40. mons[i].idx=i;
  41. }
  42. }
  43.  
  44. void solve()
  45. {
  46. sort(mons+,mons+n+);
  47. for(int i=;i<=n;i++)
  48. {
  49. hp-=mons[i].atk;
  50. if(hp<=)
  51. {
  52. failed=true;
  53. break;
  54. }
  55. hp+=mons[i].rec;
  56. }
  57. }
  58.  
  59. void print()
  60. {
  61. if(failed)
  62. {
  63. cout<<"NIE"<<endl;
  64. return;
  65. }
  66. cout<<"TAK"<<endl;
  67. for(int i=;i<=n;i++)
  68. {
  69. cout<<mons[i].idx<<" ";
  70. }
  71. cout<<endl;
  72. }
  73.  
  74. int main()
  75. {
  76. read();
  77. solve();
  78. print();
  79. }

BZOJ 3709 [PA2014]Bohater:贪心【反过来考虑】的更多相关文章

  1. bzoj 3709: [PA2014]Bohater 贪心

    题目: 在一款电脑游戏中,你需要打败\(n\)只怪物(从\(1\)到\(n\)编号).为了打败第\(i\)只怪物,你需要消耗\(d_i\)点生命值,但怪物死后会掉落血药,使你恢复\(a_i\)点生命值 ...

  2. 【贪心】bzoj 3709:[PA2014]Bohater

    3709: [PA2014]Bohater Time Limit: 5 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 653  Solved:  ...

  3. BZOJ 3709: [PA2014]Bohater

    3709: [PA2014]Bohater Time Limit: 5 Sec  Memory Limit: 128 MBSec  Special JudgeSubmit: 1050  Solved: ...

  4. bzoj 3709: [PA2014]Bohater【贪心】

    先打能回血的,按消耗从小到大打: 然后按回血量降序打剩下的(把消耗和回血反着看就是上一种怪,打法一样): 中间体力小于0就输出无解 #include<iostream> #include& ...

  5. 【BZOJ 3709: [PA2014]Bohater】

    首先,这是我n久之前培训的时候老师讲的题目了,今天突然看到,那就讲讲吧. 首先,我们考虑怎么打怪... 显然,我们需要保证这个怪要尽可能的打死(就是尽量不被干死),并且保证尽可能的净获得血量大的在前面 ...

  6. 3709: [PA2014]Bohater

    3709: [PA2014]Bohater 或者:Bohater 题解 好狠啊这个题 z 要开 long long ,可能算掉血回血的时候会爆 long long 吧 首先把能回血的怪打死(不然你后面 ...

  7. 【BZOJ】3709: [PA2014]Bohater(贪心)

    http://www.lydsy.com/JudgeOnline/problem.php?id=3709 很水的题...但是由于脑洞小..漏想了一种情况.. 首先显然能补血的先杀.. 然后杀完后从补血 ...

  8. 【BZOJ4619/3709】[Wf2016]Swap Space/[PA2014]Bohater 贪心

    [BZOJ4619][Wf2016]Swap Space Description 你有许多电脑,它们的硬盘用不同的文件系统储存数据.你想要通过格式化来统一文件系统.格式化硬盘可能使它的容量发生变化.为 ...

  9. BZOJ 3716 [PA2014]Muzeum 贪心SET最大闭合子图

    看上去像是一个最大权闭合子图裸题但是数据太大 我们可以先把守卫的视野转换到第二象限(每个守卫可以看到横坐标比他小 纵坐标比他大的宝物) 然后按X从小到大 再按Y从大到小排 这样我们就可以按SORT序遍 ...

随机推荐

  1. Linux测网速

    $ wget https://raw.github.com/sivel/speedtest-cli/master/speedtest_cli.py$ chmod a+rx speedtest_cli. ...

  2. SM Java实现

    [摘要] 本文主要解说"国密加密算法"SM系列的Java实现方法,不涉及详细的算法剖析,在网络上找到的java实现方法比較少.切在跨语言加密解密上会存在一些问题.所以整理此文志之. ...

  3. .net mvc项目 ajax

    经常在后台用一般处理程序(.ashx)来处理前台的ajax请求 using System; using System.Collections.Generic; using System.IO; usi ...

  4. java与javax有什么区别?

    http://zhidao.baidu.com/question/8702158.html java和javax都是Java的API包,java是核心包,javax的x是extension的意思,也就 ...

  5. 25:坐标移动CoordinateMove

    题目描述 开发一个坐标计算工具, A表示向左移动,D表示向右移动,W表示向上移动,S表示向下移动.从(0,0)点开始移动,从输入字符串里面读取一些坐标,并将最终输入结果输出到输出文件里面. 输入: 合 ...

  6. LVS + KEEPALIVED + WINDOWS SERVER 2008 R2 ------高可用负载均衡(转)

    工作原理此处不作讲解,自己去官方网站学习(http://www.linuxvirtualserver.org),这里重点讲如何配置!注:最好从官方网站对其进行了解,不至于会对某些问题产生误解,尽管是英 ...

  7. dede中可以用系统设置中的添加新变量来调用频繁改变的文字内容

    这样真正使所有内容都可以在后台控制.

  8. 关于React的Container&Presentational Component模型结构分析

    react.js javascript 3 之前翻译了两篇关于Container&Presentational Component模型的文章,一篇是基础的Container和Component ...

  9. [Python]xlrd 读取excel 日期类型2种方式

    有个excle表格须要做一些过滤然后写入数据库中,可是日期类型的cell取出来是个数字,于是查询了下解决的办法. 主要的代码结构 data = xlrd.open_workbook(EXCEL_PAT ...

  10. Android API Guides---Storage Access Framework

    存储訪问架构 Android 4.4系统(API级别19)推出存储訪问框架(SAF).新加坡武装部队变得很easy,为用户在其全部自己喜欢的文件存储提供商的浏览和打开文档,图像和其它文件.一个标准的, ...