【期望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同学会告诉 ...
随机推荐
- JS数组去重精简版
看了很多人写的好几个去重方法,我在这里精简组合下,适用于已排序与未排序的数组. 废话不多说,上代码. <!DOCTYPE html> <html> <head> & ...
- Luogu P4403 [BJWC2008]秦腾与教学评估【二分答案】By cellur925
题目传送门 这道题:真·凉心出题人. 二分答案,个人感觉其实并不只适用于有明显的"最大值最小/最小值最大"条件的题目,其实也可以称它为一种"优化的暴力".这题就 ...
- python爬虫——web前端基础(4)
CSS,指层叠样式表,用来定义如何显示HTML元素,一般和HTML配合使用. 在HTML中使用CSS样式的方法: 内联样式表:CSS代码直接写在现有的HTML标记中,直接使用style属性改变样式.例 ...
- Javascript 给table动态增、删除行
操作 HTML DOM Table 对象 即可 http://www.runoob.com/jsref/dom-obj-table.html 动态给一个元素焦点,用focus()方法
- linux 初始配置(centos)-网络和可视化界面
1. 执行命令查看ip:ip addr 2. 如果没有或取到,要查看网卡是否启动,及ip配置是否正确,请先将ONBOOT改成yes,表示开机即启动 [lobin@localhost ~]$ cat / ...
- 自动化测试资源(二):火狐浏览器驱动 geckodriver
geckodriver:https://github.com/mozilla/geckodriver geckodriver 历史版本下载列表:https://github.com/mozilla/g ...
- windows/Linux下设置ASP.Net Core开发环境并部署应用
10分钟学会在windows/Linux下设置ASP.Net Core开发环境并部署应用 创建和开发ASP.NET Core应用可以有二种方式:最简单的方式是通过Visual Studio 2017 ...
- 转 DataGuard环境搭建 (一主一备一级联)
DataGuard环境搭建 (一主一备一级联) http://blog.itpub.net/30130773/viewspace-2116985/ 1.--------- primary_role / ...
- 1121 - Reverse the lights 思维题
http://www.ifrog.cc/acm/problem/1121 我看到这些翻转的题就怕,可能要练下这些专题. 我最怕这类题了. 一开始想了下dp, dp[i][0 / 1]表示完成了前i位, ...
- 记录下这周的mysql调优工作
这周一至周四基本都在做mysql的测试和调优工作,包括erlang端对mysql的写入测试,到今天为止暂且告一段落,下周先做下其他的开发. 测试环境 使用的测试环境是aliyun的杭州节点 ...