题目来源: CodeForces
基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题

哈利喜欢玩角色扮演的电脑游戏《蜥蜴和地下室》。此时,他正在扮演一个魔术师。在最后一关,他必须和一排的弓箭手战斗。他唯一能消灭他们的办法是一个火球咒语。如果哈利用他的火球咒语攻击第i个弓箭手(他们从左到右标记),这个弓箭手会失去a点生命值。同时,这个咒语使与第i个弓箭手左右相邻的弓箭手(如果存在)分别失去b(1 ≤ b < a ≤ 10)点生命值。

因为两个端点的弓箭手(即标记为1和n的弓箭手)与你相隔较远,所以火球不能直接攻击他们。但是哈利能用他的火球攻击其他任何弓箭手。

每个弓箭手的生命值都已知。当一个弓箭手的生命值小于0时,这个弓箭手会死亡。请求出哈利杀死所有的敌人所需使用的最少的火球数。

如果弓箭手已经死亡,哈利仍旧可以将他的火球扔向这个弓箭手。

Input
  1. 第一行包含3个整数 n, a, b (3  n  10; 1  b < a  10),第二行包含n个整数——h1h2,...,hn (1  hi  15), hi 是第i个弓箭手所拥有的生命力。
Output
  1. 以一行输出t——所需要的最少的火球数。
Input示例
  1. 3 2 1
  2. 2 2 2
Output示例
  1. 3
 
 
思路:dfs之前先把1和n炸死
而且尽量不炸死
可以通过炸2或n-1把他们炸死 这样可以保证使用次数最少
有种情况:假如打爆x-1后x还活着,则说明x的血量大于x-1 因此要打爆x,此时打爆x有两种方法,就是直接打爆和通过打爆x+1来打爆x
搜索题
怀疑人生。。
  1. #include <cstdio>
  2. #define N 15
  3. int n,a,b,h[N],ans=0x7fffffff;
  4. void dfs(int pos,int sum)
  5. {
  6. if(sum>ans) return;
  7. if(pos==n) {ans=sum;return;}
  8. if(h[pos-]<) dfs(pos+,sum);
  9. int v=;
  10. if(h[pos-]>=)
  11. {
  12. v=h[pos-]/b+;
  13. h[pos-]-=v*b;
  14. h[pos]-=v*a;
  15. h[pos+]-=v*b;
  16. dfs(pos+,v+sum);
  17. h[pos-]+=v*b;
  18. h[pos]+=v*a;
  19. h[pos+]+=v*b;
  20. }
  21. int vv=h[pos]/a+;
  22. if(h[pos]>=&&vv>v)
  23. {
  24. for(int i=v+;i<=vv;++i)
  25. {
  26. h[pos-]-=b*i;
  27. h[pos]-=a*i;
  28. h[pos+]-=b*i;
  29. dfs(pos+,sum+i);
  30. h[pos-]+=b*i;
  31. h[pos]+=a*i;
  32. h[pos+]+=b*i;
  33. }
  34. }
  35. return ;
  36. }
  37. int Main()
  38. {
  39. scanf("%d%d%d",&n,&a,&b);
  40. for(int i=;i<=n;++i) scanf("%d",&h[i]);
  41. int ans1,v=h[]/b+;
  42. ans1=v;
  43. h[]-=v*b;
  44. h[]-=v*a;
  45. h[]-=v*b;
  46. if(h[n]>=)
  47. {
  48. v=h[n]/b+;
  49. h[n]-=v*b;
  50. h[n-]-=v*a;
  51. h[n-]-=v*b;
  52. ans1+=v;
  53. }
  54. dfs(,);
  55. if(ans==0x7fffffff) ans=;
  56. printf("%d\n",ans1+ans);
  57. return ;
  58. }
  59. int sb=Main();
  60. int main(int argc,char *argv[]){;}

51nod 1489 蜥蜴和地下室的更多相关文章

  1. 51nod 1489 蜥蜴和地下室(dp)

    传送门 题意 分析 dp[12][20][20][20]; // dp[a][b][c][d]第a个弓箭手面临第a-1.a.a+1个弓箭手的生命值分别为b.c.d的状态 转移巧妙,需注意 trick ...

  2. 51Nod 蜥蜴和地下室(搜索)

    哈利喜欢玩角色扮演的电脑游戏<蜥蜴和地下室>.此时,他正在扮演一个魔术师.在最后一关,他必须和一排的弓箭手战斗.他唯一能消灭他们的办法是一个火球咒语.如果哈利用他的火球咒语攻击第i个弓箭手 ...

  3. 51nod蜥蜴与地下室(1498)(暴力搜索)

    题意:一个数组s,再给你a,b值,除了s1和sn外,你可以攻击其他元素,你对这个元素的伤害为a,那么他两边的元素会受到b的牵连伤害,si-a,si-1-b,si+1-b: 求最小的次数,使得这个数组的 ...

  4. 【51Nod 1244】莫比乌斯函数之和

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1244 模板题... 杜教筛和基于质因子分解的筛法都写了一下模板. 杜教筛 ...

  5. 1066: [SCOI2007]蜥蜴

    1066: [SCOI2007]蜥蜴 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 3545  Solved: 1771[Submit][Status] ...

  6. 51Nod 1268 和为K的组合

    51Nod  1268  和为K的组合 1268 和为K的组合 基准时间限制:1 秒 空间限制:131072 KB 分值: 20 难度:3级算法题 给出N个正整数组成的数组A,求能否从中选出若干个,使 ...

  7. 51Nod 1428 活动安排问题

    51Nod   1428  活动安排问题 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1428 1428 活 ...

  8. 51Nod 1278 相离的圆

    51Nod 1278 相离的圆 Link: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1278 1278 相离的圆 基 ...

  9. 【51Nod 1501】【算法马拉松 19D】石头剪刀布威力加强版

    http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1501 dp求出环状不连续的前缀和,剩下东西都可以算出来,比较繁琐. 时间 ...

随机推荐

  1. nodejs写文件

    var fs = require('fs'); 2 var txt = "以上程序使用fs.readFileSync从源路径读取文件内容,并使用fs.writeFileSync将文件内容写入 ...

  2. POJ-3616

    Milking Time Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10434   Accepted: 4378 Des ...

  3. IOSerialize,xml和json,soap序列化器,二进制序列化器,XML序列化器,文件 检查、新增、复制、移动、删除

    1 文件夹/文件 检查.新增.复制.移动.删除,2 文件读写,记录文本日志/读取配置文件3 三种序列化器4 xml和json1.文件夹/文件 检查.新增.复制.移动.删除,2 文件读写,记录文本日志/ ...

  4. Oracle判断某个表是否存在的方法

    在SQL中,我们常常使用if exists来判断一个表或某个对象是否存在,例如:  IF EXISTS (SELECT * FROM sys.tables WHERE name = 'CODE_BMD ...

  5. SP2-0734: 未知的命令开头 “IMP ” - 忽略了剩余的行

    描述 在cmd命令窗口中使用imp命令将dmp文件导入到oracle中时,出现了错误: SP2-0734: 未知的命令开头 “IMP ” - 忽略了剩余的行,如图 原因 imp命令是oracle提供的 ...

  6. cogs 2691. Sumdiv

    2691. Sumdiv ★★★   输入文件:sumdiv.in   输出文件:sumdiv.out   简单对比时间限制:1 s   内存限制:12 MB [题目描述] 考虑两个自然数A和B.定义 ...

  7. Spring Cloud与Duddo比较(非原创)

    文章大纲 一.Spring Cloud与Duddo背景介绍二.Spring Cloud与Duddo比较三.参考文章   一.Spring Cloud与Duddo背景介绍   国内技术人员喜欢拿 Dub ...

  8. easyui datagrid编辑时编辑框自动获取焦点

    onDblClickCell:function(rowIndex, field, val){//双击单元格监听器 $(this).datagrid('beginEdit',rowIndex);//开启 ...

  9. Python面向对象之单例模式

    单例模式(Singleton Pattern)是一种常用的软件设计模式,该模式的主要目的是确保某 一个类只有一个实例存在.当你希望在整个系统中,某个类只能出现一个实例时,单例对象就 能派上用场. 单例 ...

  10. QDU-GZS and String

    Description GZS has two strings s and t. In each step, GZS can select arbitrary character c of s and ...