恐怖的奴隶主(bob)
题目描述
出。
当一只BigBob受到伤害后,假如它没有死亡且剩余血量为t,它会从左数第 一个空格处召唤一只血量为a[t]的BigBob;若没有空格,则不会召唤。
法术R定义为:从左往右,对每个BigBob造成一点伤害;假如有BigBob死 亡,重复上述效果。
聪明的小L发现,在某些情况下,当他发动法术R时,游戏会陷入循环。 他想求出这样的初始情形有多少种。
输入
随后一行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。
解析:
bool pd1[][][][],f;
void pd()
{
memset(pd1,,sizeof(pd1));
while()
{
f=;
pd1[gz[]][gz[]][gz[]][gz[]]=;
for(int i=;i<=;i++)
{
if(gz[i]==)f=;
if(gz[i]>=)gz[i]--;
for(int j=;j<=;j++)
{
if(i==j)continue;
if(gz[j]==)
{
gz[j]=a[gz[i]];
break;
}
}
}
if(gz[]+gz[]+gz[]+gz[]==||f==)
{
return;
}
if(pd1[gz[]][gz[]][gz[]][gz[]])
{
total++;
return;
}
}
}
void dfs(int t)
{
for(int i=;i<=k;i++)
{
gz[t]=i;
if(t==)pd();
else dfs(t+);
}
}
这个程序,又T又WA,可谓是WA,T两开花~,今年下半年中美合拍的西游记即将正式开机。。。
最后上AC代码:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int k,a[],gz[],total,s,now[];
bool pd1[][][][],f;//pd不能开太大,否则会T
inline void pd()
{
memset(pd1,,sizeof(pd1));
/*cout<<gz[1]<<" "<<gz[2]<<" "<<gz[3]<<" "<<gz[4]<<endl;*/
for(int i=;i<=;i++)gz[i]=now[i];//不能用排列的数组,否则会WA
while()
{
f=;
pd1[gz[]][gz[]][gz[]][gz[]]=;
for(int i=;i<=;i++)
{
if(gz[i]<) continue;
gz[i]--;
if(gz[i]==)
{
f=;
continue;
}
for(int j=;j<=;j++)
{
if(i==j)continue;
if(gz[j]==)
{
gz[j]=a[gz[i]];
break;
}
}
}
if(gz[]+gz[]+gz[]+gz[]==||!f)return;
if(pd1[gz[]][gz[]][gz[]][gz[]])
{
total++;
return;
}
}
}
inline void dfs(int t)//生成四个格子的排列
{
if(t==)
{
pd();
return;
}
for(int i=;i<=k;i++)
{
now[t]=i;
dfs(t+);
}
}
int main()
{
cin>>k;
for(int i=;i<=k-;i++)cin>>a[i];
dfs();
cout<<total;
return ;
}
时间复杂度最大为O(15*15*15*15*(memset函数速度蒟蒻不会算+10(pd函数while(1)运行的平均次数))≈ O(8100000);稳~
这篇题解这么好,不关注+素质三连吗???
恐怖的奴隶主(bob)的更多相关文章
- 恐怖的奴隶主(bob)
题目 试题3:恐怖的奴隶主(bob) 源代码:bob.cpp 输入文件:bob.in 输出文件:bob.out 时间限制:1s 空间限制:512MB 题目描述 小L热衷于undercards. 在un ...
- 【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 ...
- [清华集训]小 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 ...
随机推荐
- Panabit镜像功能配合wireshark抓包的方法
Panabit镜像功能配合wireshark抓包的方法 Panabit的协议识别都是基于数据包的特征,因此捕获数据包样本是我们进行识别第一步要做的事情.下面就和大家说一下如何捕获网络应用的数据包. 到 ...
- JSON —— 数据结构
1.什么是 JSON JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式. 易于人阅读和编写 JSON 采用完全独立于语言的文本格式,但是也使用了类似于 C ...
- elasticsearch 基础 —— Field Collapsing字段折叠
允许根据字段值折叠搜索结果.通过按折叠键选择顶部排序文档来完成折叠.例如,下面的查询检索每个用户的最佳推文,并按喜欢的数量对它们进行排序. GET /twitter/_search { "q ...
- oralce 日期 date 相关操作
1.当前时间加减一年 加一年 select sysdate,add_month(sysdate,12) from dual; 减一年 select sysdate,add_month(sysdate, ...
- html5中play 方法和pause方法在video的应用
play();播放 pause();暂停 代码实例: <!DOCTYPE html> <html lang="en"> <head> <m ...
- office2016pro专业版命令行激活
1.首先查看Office2016安装目录在哪里,如果是默认安装,没有修改路径,是在C:\Program Files\Microsoft Office\Office16目录下,具体路径还得自行查看,我的 ...
- Window下设置Octave
从 http://sourceforge.net/projects/octave/files/Octave_Windows%20-%20MinGW/Octave%203.6.0%20for%20Win ...
- controllerpom
<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> &l ...
- SpringBoot JSON文件读取
@Componentpublic class StepExecutor implements Runnable { @Value("classpath:menu.json") pr ...
- 【锁】MySQL和Oracle行锁比较
InnoDB INNODB表是索引组织的表,主键是聚集索引,非主键索引都包含主键信息. INNODB默认是行锁. INNODB行锁是通过给索引项加锁来实现的,即只有通过索引条件检索数据,InnoDB才 ...