【期望dp】bzoj4832: [Lydsy1704月赛]抵制克苏恩
这个题面怎么这么歧义……
Description
Input
Output
对于每局游戏,输出一个数字表示总伤害的期望值,保留两位小数。
题目分析
期望dp是真的太不熟了……暴力都能打挂。
#include<cstdio> int T,k,a,b,c;
double ans; void dfs(int done, int n1, int n2, int n3, int bld, double sta)
{
if (done==k||!bld) return;
if (n1) dfs(done+, n1-, n2, n3, bld, sta*n1/(n1+n2+n3+1.0));
if (n2){
if (n1+n2+n3 < )
dfs(done+, n1+, n2-, n3+, bld, sta*n2/(n1+n2+n3+1.0));
else dfs(done+, n1+, n2-, n3, bld, sta*n2/(n1+n2+n3+1.0));
}
if (n3){
if (n1+n2+n3 < )
dfs(done+, n1, n2+, n3, bld, sta*n3/(n1+n2+n3+1.0));
else dfs(done+, n1, n2+, n3-, bld, sta*n3/(n1+n2+n3+1.0));
}
ans += sta/(n1+n2+n3+1.0);
dfs(done+, n1, n2, n3, bld, sta/(n1+n2+n3+1.0));
}
int main()
{
freopen("cthun.in","r",stdin);
freopen("cthun.out","w",stdout);
scanf("%d",&T);
while (T--)
{
ans = ;
scanf("%d%d%d%d",&k,&a,&b,&c);
dfs(, a, b, c, , 1.0);
printf("%.2lf\n",ans);
}
return ;
}
这个是暴力。标红部分意味着:对于n个奴隶主,攻击他们其中一个是不相同的,所以转移到这个状态的概率要乘n。
那么期望dp通常来说状态是倒着表示的:$f[t][i][j][k]$表示初始状态为$(t,i,j,k)$,最终的获得期望是多少。这样做的好处在于,可以预处理出所有的初始状态,并且转移时候会更加方便,不需要记录转移的概率。
所以这也算是一个需要灵活应用的点吧。
#include<cstdio>
#include<cctype> int T,k,a,b,c;
double f[][][][]; int read()
{
int num = ;
bool fl = ;
char ch = getchar();
for (; !isdigit(ch); ch=getchar())
if (ch=='-') fl = ;
for (; isdigit(ch); ch=getchar())
num = (num<<)+(num<<)+ch-;
if (fl) num = -num;
return num;
}
int main()
{
freopen("cthun.in","r",stdin);
freopen("cthun.out","w",stdout);
for (int t=; t<=; t++)
for (int i=; i<=; i++)
for (int j=; i+j<=; j++)
for (int k=; i+j+k<=; k++)
{
double sum = i+j+k+1.0;
f[t][i][j][k] += (f[t-][i][j][k]+)/sum;
f[t][i][j][k] += f[t-][i-][j][k]*i/sum;
if (i+j+k < )
f[t][i][j][k] += f[t-][i+][j-][k+]*j/sum,
f[t][i][j][k] += f[t-][i][j+][k]*k/sum;
else
f[t][i][j][k] += f[t-][i+][j-][k]*j/sum,
f[t][i][j][k] += f[t-][i][j+][k-]*k/sum;
}
T = read();
while (T--) printf("%.2lf\n",f[read()][read()][read()][read()]);
return ;
}
END
【期望dp】bzoj4832: [Lydsy1704月赛]抵制克苏恩的更多相关文章
- BZOJ4832[Lydsy1704月赛]抵制克苏恩——期望DP
题目描述 小Q同学现在沉迷炉石传说不能自拔.他发现一张名为克苏恩的牌很不公平.如果你不玩炉石传说,不必担心,小Q 同学会告诉你所有相关的细节.炉石传说是这样的一个游戏,每个玩家拥有一个 30 点血量的 ...
- BZOJ4832: [Lydsy1704月赛]抵制克苏恩(期望DP)
Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 913 Solved: 363[Submit][Status][Discuss] Description ...
- BZOJ4832: [Lydsy1704月赛]抵制克苏恩(记忆化&期望)
Description 小Q同学现在沉迷炉石传说不能自拔.他发现一张名为克苏恩的牌很不公平.如果你不玩炉石传说,不必担心,小Q 同学会告诉你所有相关的细节.炉石传说是这样的一个游戏,每个玩家拥有一个 ...
- BZOJ4832: [Lydsy1704月赛]抵制克苏恩 (记忆化搜索 + 概率DP)
题意:模拟克苏恩打奴隶战对对方英雄所造成的伤害 题解:因为昨(今)天才写过记忆化搜索 所以这个就是送经验了 1A还冲了个榜 但是我惊奇的发现我数组明明就比数据范围开小了啊??? #include &l ...
- [bzoj4832][Lydsy1704月赛]抵制克苏恩
题目大意:有一个英雄和若干个所从,克苏恩会攻击$K$次,每次回随机攻击对方的一个人,造成$1$的伤害.现在对方有一名克苏恩,你有一些随从.如果克苏恩攻击了你的一名随从,若这名随从不死且你的随从数量不到 ...
- 【bzoj4832】[Lydsy1704月赛]抵制克苏恩 期望dp
Description 小Q同学现在沉迷炉石传说不能自拔.他发现一张名为克苏恩的牌很不公平.如果你不玩炉石传说,不必担心,小Q 同学会告诉你所有相关的细节.炉石传说是这样的一个游戏,每个玩家拥有一个 ...
- BZOJ.4832.[Lydsy1704月赛]抵制克苏恩(期望DP)
题目链接 \(f[s][i][j][k]\)表示还剩\(s\)次攻击,分别有\(i,j,k\)个血量为\(1,2,3\)的奴隶主时,期望受到伤害. 因为期望是倒推,所以这么表示从后往前求,注意\(a, ...
- [Bzoj4832][Lydsy2017年4月月赛]抵制克苏恩 (期望dp)
4832: [Lydsy2017年4月月赛]抵制克苏恩 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 673 Solved: 261[Submit][ ...
- 【BZOJ4832】[Lydsy2017年4月月赛]抵制克苏恩 概率与期望
[BZOJ4832][Lydsy2017年4月月赛]抵制克苏恩 Description 小Q同学现在沉迷炉石传说不能自拔.他发现一张名为克苏恩的牌很不公平.如果你不玩炉石传说,不必担心,小Q同学会告诉 ...
随机推荐
- 【ZJOI2007】捉迷藏 小小的总结
2019-01-09 22:56:33 终于终于把这道题目做掉了... 做了两个晚上..不知道为什么自己如此之笨.. 在洛谷上断断续续一共交了24次,感觉自己都要被封号了. 昨天花半个晚上从零开始研究 ...
- Linux下FTP用户的使用配置
1.创建本地账户,用户名为自己的姓名拼音,使用本地用户测试,从以下几个方面来观察,账户 .密码.访问目录(可否查看上级目录) .上传下载的权限.
- STP-11-多生成树:IEEE 802.1s
IEEE802.1s多生成树(MultipleSpanningTrees,MST)有时也称为多STP(MultipleSTP,MSTP),它定义了在使用802.1QVLAN网络中,部署多实例STP的标 ...
- BZOJ2595(状压dp)
要点 设\(f[i][j][k]\)为经过点\((i,j)\)且包含点集\(k\)的最小代价,其中k是指景点集合的枚举. 考虑有两种情况:1.点\((i,j)\)作为关键点连接了两个子集时\(f[i] ...
- NOI2015软件包管理器 树剖线段树
题目: 一棵树,兹磁 1.查询根到一个点的染色点数并全染好 2.查询子树内染色点数并把颜色洗掉 树剖裸题,丝毫不虚(为什么我考试的时候碰不到这种好题呢)好像20min写完搞定 #include < ...
- 爬虫(ProxyHandler)——代理
工具:python3 步骤: 1)使用ProxyHandler()构建httpproxy_handler对象 2)使用build_opener(httpproxy_handler)构建opener 3 ...
- Codeforces Beta Round #96 (Div. 2) E. Logo Turtle dp
http://codeforces.com/contest/133/problem/E 题目就是给定一段序列,要求那个乌龟要走完整段序列,其中T就是掉头,F就是向前一步,然后开始在原点,起始方向随意, ...
- Ubuntu搭建WordPress-MySQL-Apache
目标 技术博客www.xifarm.com有5年时间了. 原来在虚拟机/VPS上搭建,不过都是Windows系统下的. 最近突发奇想,试试迁移到Linux的Unbuntu下.说干就干,抽空用了大约3天 ...
- php文件缓存数据
最近在做微信的摇一摇跑马活动,实现原理是用户摇动手机,通过ajax往数据库写入数据(小马跑的步数),然后PC端用过ajax每一秒钟从数据库中调取一次数据(小马跑的步数),然后显示在PC屏幕上,这样就会 ...
- C# 实现本地化日志管理
1.新建一个类库解决方案 CommnoLog 2.新建两个文件夹 2.1FileUtil.cs 代码如下 public static class FileUtil { /// <summary ...