恐怖的奴隶主(bob)
题目
试题3:恐怖的奴隶主(bob)
源代码:bob.cpp
输入文件:bob.in
输出文件:bob.out
时间限制:1s
空间限制:512MB
题目描述
小L热衷于undercards.
在undercards中,有四个格子。每个格子要么是空的,要么住着一只BigBob。
每个BigBob有一个不超过k的血量;血量减到0视为死亡。那个格子随即空
出。
当一只BigBob受到伤害后,假如它没有死亡且剩余血量为t,它会从左数第
一个空格处召唤一只血量为a[t]的BigBob;若没有空格,则不会召唤。
法术R定义为:从左往右,对每个BigBob造成一点伤害;假如有BigBob死
亡,重复上述效果。
聪明的小L发现,在某些情况下,当他发动法术R时,游戏会陷入循环。
他想求出这样的初始情形有多少种。
输入输出说明
输入一个正整数k;
随后一行k-1个正整数,表示a[1]~a[k-1];
输出一个整数,表示答案。
样例输入
2
2
样例输入
31
样例解释
Bigbob最多有2血,满血bigbob受伤会召出新的。
循环的初始状态有:
(2,1,0,0),(1,2,0,0),(2,0,1,0),(2,1,1,0),(0,2,1,0),(1,2,1,0),(2,2,1,0) ,(1,0,2,0),(0,1,2,0),(1,1,2,0),(2,1,2,0),(2,1,0,1),(0,2,0,1),(1,2,0,1),(0,2,1,1),(1,2,1,1),(0,0,2,1),(1,0,2,1),(0,1,2,1),(1,1,2,1),(2,1,2,1),(0,2,2,1),(1,2,2,1),(2,1,0,2) ,(1,2,0,2),(2,0,1,2),(2,1,1,2),(0,2,1,2),(1,2,1,2),(2,2,1,2),(2,1,2,2)
共31种。
数据范围
对于30%的数据,k≤5;
对于70%的数据,k≤10, a[i]=k;
对于100%的数据,k≤15, 1≤a[i]≤k。
分析
(这里我不得不吐槽一下:这道题作者的语文老师应该是一个教数学的体育老师吧)
这里我解释一下题目。(可能有很多人栽在了这里,包括我……)
首先每次从左到右对每一只BigBob进行1血的攻击。
攻击过程中若一只BigBob没死它会立即在从左到右的第一个空地上“生”出一个血量为a[t](t为BigBob的剩余)的“新”BigBob。(若无空地,则不会有“新”BigBob)
攻击过程中若一只BigBob死亡,则该BigBob的位置会变为空地。
若进行完一轮(一轮:从左到右对每一只BigBob进行1血的攻击)攻击后没有任何一只BigBob死亡或全部变为空地,则循环结束。
因为这道题的数据量很小又为了保险起见,所以我们采用暴力(模拟)。(这里我要感谢一下作者~)
大体思路是:先枚举每一个循环的初始状态(最多154种情况),再判断是否循环。
代码
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
long long k,s[40],t[11000],ans=0;
bool flag[16][16][16][16];//记录已出现过的情况
inline void dfs(int x)
{
if(x==5)
{
int a=s[1],b=s[2],c=s[3],d=s[4];
memset(flag,0,sizeof(flag));
while(1)
{
flag[a][b][c][d]=1;
bool fflag=0;//记录有没有BigBob死亡
if(a==1 || b==1 || c==1 || d==1) fflag=1;
a=max(a-1,0);//不攻击空地
if(a)//如果BigBob受伤但未死
{
if(!b) b=t[a];
else if(!c) c=t[a];
else if(!d) d=t[a];
}
if(b==1) fflag=1;
b=max(b-1,0);
if(b)
{
if(!a) a=t[b];
else if(!c) c=t[b];
else if(!d) d=t[b];
}
if(c==1) fflag=1;
c=max(c-1,0);
if(c)
{
if(!a) a=t[c];
else if(!b) b=t[c];
else if(!d) d=t[c];
}
if(d==1) fflag=1;
d=max(d-1,0);
if(d)
{
if(!a) a=t[d];
else if(!b) b=t[d];
else if(!c) c=t[d];
}
if(a+b+c+d==0 || !fflag) return;//判单是否已结束
if(flag[a][b][c][d])//判断是否出现过
{
ans++;
return;
}
}
}
for(int i=0;i<=k;i++)//枚举所有情况
{
s[x]=i;
dfs(x+1);
}
}
int main()
{
cin>>k;
for(int i=1;i<k;i++) cin>>t[i];
dfs(1);
cout<<ans;
return 0;
}
恐怖的奴隶主(bob)的更多相关文章
- 【UOJ#340】【清华集训2017】小 Y 和恐怖的奴隶主(矩阵快速幂,动态规划)
[UOJ#340][清华集训2017]小 Y 和恐怖的奴隶主(矩阵快速幂,动态规划) 题面 UOJ 洛谷 题解 考虑如何暴力\(dp\). 设\(f[i][a][b][c]\)表示当前到了第\(i\) ...
- loj #2325. 「清华集训 2017」小Y和恐怖的奴隶主
#2325. 「清华集训 2017」小Y和恐怖的奴隶主 内存限制:256 MiB时间限制:2000 ms标准输入输出 题目类型:传统评测方式:文本比较 题目描述 "A fight? Co ...
- 恐怖的奴隶主(bob)
题目描述 小L热衷于undercards. 在undercards中,有四个格子.每个格子要么是空的,要么住着一只BigBob. 每个BigBob有一个不超过k的血量:血量减到0视为死亡.那个格子随即 ...
- [清华集训]小 Y 和恐怖的奴隶主
题面在这里 题意 有一个\(Boss\)和他血量为\(m\)的随从奴隶主,每当奴隶主受到攻击且不死,并且\(Boss\)的随从个数\(<k\)时,就会新召唤一个血量为\(m\)的奴隶主.每次攻击 ...
- 【loj2325】「清华集训 2017」小Y和恐怖的奴隶主 概率dp+倍增+矩阵乘法
题目描述 你有一个m点生命值的奴隶主,奴隶主受伤未死且当前随从数目不超过k则再召唤一个m点生命值的奴隶主. T次询问,每次询问如果如果对面下出一个n点攻击力的克苏恩,你的英雄期望会受到到多少伤害. 输 ...
- LOJ2325. 「清华集训 2017」小 Y 和恐怖的奴隶主【矩阵快速幂优化DP】【倍增优化】
LINK 思路 首先是考虑怎么设计dp的状态 发现奴隶主的顺序没有影响,只有生命和个数有影响,所以就可以把每个生命值的奴隶主有多少压缩成状态就可以了 然后发现无论是什么时候一个状态到另一个状态的转移都 ...
- uoj#340. 【清华集训2017】小 Y 和恐怖的奴隶主(矩阵加速)
传送门 uoj上的数据太毒了--也可能是我人傻常数大的缘故-- 三种血量的奴隶主加起来不超过\(8\)个,可以枚举每种血量的奴隶主个数,那么总的状态数只有\(165\)种,设\(dp_{t,i,j,k ...
- LOJ2325「清华集训 2017」小Y和恐怖的奴隶主
题目链接 首先dp很显然,\(f(i,s)\)表示到了第i轮,各种血量人数的情况为s今后的期望攻击boss次数.那么有\(f(i,s)=\frac{1}{num+1}*\sum_{s->s'}( ...
- 洛谷P4007 小 Y 和恐怖的奴隶主(期望dp 矩阵乘法)
题意 题目链接 Sol 首先不难想到一种暴力dp,设\(f[i][a][b][c]\)表示还有\(i\)轮没打,场上有\(a\)个1血,\(b\)个2血,\(c\)个三血 发现状态数只有\(s = 1 ...
随机推荐
- swift语言点评八-枚举
总结:swift中的枚举可以看作变量可以作为case匹配参数的类 Enumerations 枚举的作用:状态列举与匹配 枚举值与类型 If a value (known as a “raw” valu ...
- Sublime Text编辑器配置Python解释器简易教程
前天在微信上遇到一个小伙伴问我一个关于Sublime text配置Python解释器的问题,可能是初学者,对这方面还不是很懂,想使用快捷键但是徒劳一场,因为缺少Python解释器,直接按下快捷键Ctr ...
- java上传文件工具类
这个是之前整理之前所学时与使用java向邮箱发送邮件一块找到的,一起贴出来供大家参考: import java.awt.image.BufferedImage; import java.io.File ...
- LightOJ-1336 Sigma Function 唯一分解定理 巧妙使用sqrt()等算数目
题目链接:https://cn.vjudge.net/problem/LightOJ-1336 题意 给出一个区间[1, n],求区间内所有数中因数之和为偶数的数目 思路 第二次写这个题 首先想到唯一 ...
- CodeForces-920E Connected Components? 广度搜索 双向链表 判断联通 大量重复节点的删除
题目链接:https://cn.vjudge.net/problem/CodeForces-920E 题意 给一个补图,问各个联通块有几个元素,升序排列 注意maxn=2e5, maxm=2e10 思 ...
- mycat详细
MyCAT的优势基于阿里开源的Cobar产品而研发,Cobar的稳定性.可靠性.优秀的架构和性能以及众多成熟的使用案例使得MYCAT一开始就拥有一个很好的起点,站在巨人的肩膀上,我们能看到更远.业界优 ...
- SSIS安装以及安装好找不到商业智能各种坑
原文:SSIS安装以及安装好找不到商业智能各种坑 这两天为了安装SSIS,各种头疼.记录一下,分享给同样遇到坑的.. 安装SSIS需要几个步骤. 先说一下我的情况,安装SQL的时候,一直默认下一步,没 ...
- python中的try...except...finally函数
异常Error 我们在写代码的时候,经常会遇见程序抛出Error无法执行的情况 一般情况下,在Python无法正常处理程序时就会发生一个异常.异常是Python对象,表示一个错误.当Python脚本发 ...
- 【BZOJ 1150】[CTSC2007]数据备份Backup
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 选择的连接肯定是相邻的点对. 那么我们处理出来长度为n-1的数组a 其中a[i-1] = dis[i]-dis[i-1] 那么问题就 ...
- hadoop-10-创建yum资源库
hadoop-10-创建yum资源库 1,在/etc/yum.repos.d/下面创建 ambari.repo HDP.repo HDP-UTILS.repo 三个文件: [root@server ...