题解-CF1396C Monster Invaders
题面
有 \(n\) 层关卡,每层有 \(a_i\) 个小怪(\(1\) 血)和 \(1\) 个老怪(\(2\) 血)。有三种武器:\(1\) 武器每次攻击耗时 \(r_1\),可以攻击一个怪 \(1\) 血;\(2\) 武器每次攻击耗时 \(r_2\),可以攻击一层每个怪 \(1\) 血;\(3\) 武器每次攻击耗时 \(r_3\),可以杀死一个怪。当一次攻击伤害了老怪但是没有杀死他时,玩家会被迫移动至相邻的层;也可以主动移至相邻的层。刚开始时在 \(1\) 层,每次移动耗时 \(d\),求最后杀死所有怪的最少耗时(不一定要在 \(n\) 层结束)。
数据范围:\(2\le n\le 10^6\),\(1\le r_1\le r_2\le r_3\le 10^9\),\(1\le d\le 10^9\),\(1\le a_i\le 10^6\)。
蒟蒻语
开学前最后一场比赛因为这题卡住了掉回了 CM,真是悲伤。当时少看了 \(r_1\le r_2\le r_3\) 这个条件,AC 后才看到(所以即使没有这个条件蒟蒻的代码可能也可以 AC)。于是彻底失败的蒟蒻决定卧薪尝胆,做了这题写题解。
蒟蒻解
首先很明显,打每一层都有两种打法:
- 分次打,先用 \(2\) 或 \(1\) 把 boss 打残,把小兵都打死,然后到时候回来补一刀(用 \(1\))。
\]
- 一次打掉,用 \(1\) 把 \(a_i\) 个依次打掉,然后用 \(3\) 把 boss 干掉。
\]
除了 \(st_i\) 和 \(pa_i\),剩下可以对答案产生贡献的就是如何走位(\(d\) 的贡献)。
假设每个每层如何打已经决定好,且下文中的分界点一定,可以证明如下走位最优:
对于某个分界点后一段选 \(st\) 的,可以到达终点后回来打完(详见样例 \(\#1\) 解释)。
对于分界点前一段的,从 \(1\) 出发:
对于每两个相邻的选 \(st\) 的层对 \(a,b\),走 \(a\to b\to a\to b\) 的途中将两层打完;
对于多余的选 \(st\) 的层 \(i\),走 \(i\to i\pm 1\to i\)。
对于选 \(pa\) 的,直接走过就可以。
放个抽象一点的图:

比如样例 \(\#2\):
打法选择:\([pa,pa,st,st]=6+6+6+8\)。
走位选择:\(1\to 2\to 1\to 2\to 3\to 4=5\)。
所以答案是 \(6+6+6+8+5=31\)。
所以可以先 dp 出以第 \(n\) 层为终点的前 \(i\) 层的最少打法 \(+\) 走位耗时,然后枚举分界点,两边答案加起来取最小值。
代码
#include <bits/stdc++.h>
using namespace std;
//Start
typedef long long ll;
typedef double db;
#define mp(a,b) make_pair((a),(b))
#define x first
#define y second
#define be(a) (a).begin()
#define en(a) (a).end()
#define sz(a) int((a).size())
#define pb(a) push_back(a)
#define R(i,a,b) for(int i=(a),I=(b);i<I;i++)
#define L(i,a,b) for(int i=(a),I=(b);i>I;i--)
const int iinf=0x3f3f3f3f;
const ll linf=0x3f3f3f3f3f3f3f3f;
//Main
int main(){
ios::sync_with_stdio(0);
cin.tie(0),cout.tie(0);
ll n,r1,r2,r3,d,ans=linf;
cin>>n>>r1>>r2>>r3>>d;
vector<ll> a(n),pa(n),st(n);
R(i,0,n) cin>>a[i],pa[i]=r1*a[i]+r3,st[i]=min(r2,r1*(a[i]+1))+min(min(r1,r2),r3);
vector<ll> f(n+1,linf),g(n+1); f[0]=d*(n-1);
R(i,0,n){
f[i+1]=min(f[i+1],f[i]+pa[i]);
f[i+1]=min(f[i+1],f[i]+st[i]+d*2);
if(i+1<n) f[i+2]=min(f[i+2],f[i]+st[i]+st[i+1]+d*2);
}
ans=min(ans,f[n]);
L(i,n-2,-1) g[i]=g[i+1]+min(pa[i],st[i]);
R(i,0,n-1){
ans=min(ans,f[i]+g[i]+d*(n-1-i)+pa[n-1]);
ans=min(ans,f[i]+g[i]+d*(n-1-i)+d*2+st[n-1]);
}
cout<<ans<<'\n';
return 0;
}
祝大家学习愉快!
题解-CF1396C Monster Invaders的更多相关文章
- 「题解」小 R 打怪兽 monster
本文将同步发布于: 洛谷博客: csdn: 博客园: 简书. 题目 题目描述 小 R 最近在玩一款游戏.在游戏中,小 R 要依次打 \(n\) 个怪兽,他需要打败至少 \(k\) 个怪兽才能通关.小 ...
- hdu4950 Monster (水题)
4950 Monster Monster Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others ...
- HDU 4950 Monster (水题)
Monster 题目链接: http://acm.hust.edu.cn/vjudge/contest/123554#problem/I Description Teacher Mai has a k ...
- Codeforces Round #278 (Div. 1) A. Fight the Monster 暴力
A. Fight the Monster Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/487/ ...
- Codeforces Round #328 (Div. 2) B. The Monster and the Squirrel 打表数学
B. The Monster and the Squirrel Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/c ...
- 2017 google Round C APAC Test 题解
题解参考网上的答案,以及我自己的想法. 主要参考网站:http://codeforces.com/blog/entry/47181,http://codeforces.com/blog/entry/4 ...
- 3856: Monster
3856: Monster Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 351 Solved: 161[Submit][Status][Discuss ...
- HDU暑假多校第三场H.Monster Hunter
一.题意 给定一个树状地图,每个树节点上有一只怪物,打死一只怪物的过程中将会消耗A点HP,打死之后将会获得B点HP.因为树状结构,所以每只怪物必须先打死父节点的怪兽之后在打死子节点的怪物.现在,给定每 ...
- 【bzoj3856】Monster 乱搞
题目描述 你要打一只h点血的怪物,每回合你攻击会造成a点伤害,回合结束后怪物会回b点血,你每攻击k回合需要休息一次,该回合不能造成伤害.怪物血量降到0以下就会死亡,问最后能否打死怪物. 输入 Ther ...
随机推荐
- 二、多线程及服务器编程总结------linux多线程服务端编程
- JS之DOM(一)
一.DOM简介 什么是DOM?简单地说,DOM是是针对HTML和XML文档的一个API,一套对文档的内容进行抽象和概念化的方法. 学习过ORM的同学可能知道ORM是将数据库中的表映射到类,建立一个表和 ...
- 使用qmake编译时拷贝文件
使用qmake构建项目时,需要在make时拷贝一些文件到指定位置,非执行make install,下面总结列举一下我了解的方式 COPIES 示例pro 1 COPY_DIR = $$PWD/copy ...
- python脚本打包成rpm软件包
前言 软件最终都会有交付的形式,有的是用tar包,有个是以目录,有的是封成一个文件包,从大多数使用场景来说,直接打包成软件包的方式是最简单,也是最不容易出错的,路径可以在包里面写死了 实践 关于打包的 ...
- JavaScript高级程序设计(第四版) -- 随笔 -- 数组(未完)
数组方法 .every() 与 .some() 传给两个个方法的函数都接收3个参数:数组元素.元素索引和数组本身. .every() -- 对于每一项都需要返回true,它才会返回true 若中途有一 ...
- 计算思维(美国CMU周以真教授)
博主注:GIScience会议是国际上最为著名的地理信息系统领域的国际会议,自2000年起,每两年举办一次,GIScience 2008会议邀请了美国卡内基-梅隆大学(CMU)计算机系华裔教授周以真博 ...
- 使用pdfFactory为PDF文件设定查看选项
一般情况下,大部分PDF文件都会按照默认的查看设置,以100%的尺寸显示第一页的内容.但在一些特殊情况下,PDF文件的创建者会设定其他的文件查看尺寸,或设定打开页为第N页,来达到引起阅读者关注的目的. ...
- GIF图保存下来不会动?用Folx的浏览器捕获下载功能试试!
表情包大多是GIF格式的动图,有时候使用浏览器的另存为保存完发现并不能动态播放,怎么办呢?试试Folx提供的浏览器捕获下载功能,就能将各种格式的图片,包括GIF动图的下载链接捕获下来,供进一步下载使用 ...
- Word2 word输入公式+文字转表格
1.word中输入 =rand() -点击回车键-会随机生成一段文字-可用作排版练习/虚拟的文字排版设计 ##也可以为=rand(2,3)等,括号里可以随即填写其他数字,最后生成文字字数等不一样 2. ...
- 解决Maven项目中pom.xml文件报错(Failure to transfer....)的问题
打开pom.xml文件,查看错误,如果错误类型为:Failure to transfer.........之类的,则表明你的pom中依赖的jar包没有完全下载. 解决方法:找到你本地的maven仓库, ...