【HDOJ6224】Legends of the Three Kingdoms(概率DP)
题意:三国杀,给定4个白板武将的血量,4个角色轮流行动,每回合行动时如果该人存活则可以选择使阵营不同的角色血量-1,血量为0则死亡。每个人按自己获胜概率最大化行动,如果有多种方案概率相同则等概率选择这些策略,问最后主公、反贼、内奸三个阵营分别获胜的概率
0 < h1 < 40, 0 ≤ h2 < 40, 0 ≤ h3 < 40, 0 ≤ h4 < 40
思路:当前的决策与概率只与血量和当前行动的人有关
注意行动顺序是主公,反贼,忠臣,内奸
其他的具体看代码注释吧
#include<cstdio>
#include<cstring>
#include<string>
#include<cmath>
#include<iostream>
#include<algorithm>
#include<map>
#include<set>
#include<queue>
#include<vector>
using namespace std;
typedef long long ll;
typedef unsigned int uint;
typedef unsigned long long ull;
typedef pair<int,int> PII;
typedef vector<int> VI;
#define fi first
#define se second
#define MP make_pair
#define N 11000
#define M 41
#define MOD 1e9+7
#define eps 1e-13
#define pi acos(-1) double dp[][][][][][];
bool vis[][][][][]; int read()
{
int v=,f=;
char c=getchar();
while(c<||<c) {if(c=='-') f=-; c=getchar();}
while(<=c&&c<=) v=(v<<)+v+v+c-,c=getchar();
return v*f;
} void dfs(int a,int b,int c,int d,int i)
{
if(vis[a][b][c][d][i]) return; vis[a][b][c][d][i]=; if(!c&&!d) //Both of the Rebel and the Traitor are dead
{
dp[a][b][c][d][i][]=1.0;
dp[a][b][c][d][i][]=dp[a][b][c][d][i][]=0.0;
return; //Monarch and the Minister win
} if(!a) //The Monarch is dead
{
if(a+b+c==) //If the Traitor is surviving and all the other players are dead
{
dp[a][b][c][d][i][]=1.0;
dp[a][b][c][d][i][]=dp[a][b][c][d][i][]=0.0;
return; //the Traitor wins
}
else
{
dp[a][b][c][d][i][]=1.0;
dp[a][b][c][d][i][]=dp[a][b][c][d][i][]=0.0;
return; //the Rebel wins
}
} if(i==&&a==||i==&&c==||i==&&b==||i==&&d==) //deadman turn
{
dfs(a,b,c,d,(i+)%);
for(int j=;j<=;j++) dp[a][b][c][d][i][j]=dp[a][b][c][d][(i+)%][j];
return;
} int j=(i+)%;
double s1=0.0;
double s2=0.0;
double s3=0.0;
int x=; if(i==||i==) //Monarch and the Minister
{
double t=-1.0; if(c)
{
dfs(a,b,c-,d,j);
double k=dp[a][b][c-][d][j][]; if(k-t>eps)
{
x=;
t=k;
s1=dp[a][b][c-][d][j][];
s2=dp[a][b][c-][d][j][];
s3=dp[a][b][c-][d][j][];
}
else
if(fabs(k-t)<eps)
{
x++;
s1+=dp[a][b][c-][d][j][];
s2+=dp[a][b][c-][d][j][];
s3+=dp[a][b][c-][d][j][];
}
} if(d)
{
dfs(a,b,c,d-,j);
double k=dp[a][b][c][d-][j][]; if(k-t>eps)
{
x=;
t=k;
s1=dp[a][b][c][d-][j][];
s2=dp[a][b][c][d-][j][];
s3=dp[a][b][c][d-][j][];
}
else
if(fabs(k-t)<eps)
{
x++;
s1+=dp[a][b][c][d-][j][];
s2+=dp[a][b][c][d-][j][];
s3+=dp[a][b][c][d-][j][];
}
}
} if(i==) //Rebel
{
double t=-1.0; if(a)
{
dfs(a-,b,c,d,j);
double k=dp[a-][b][c][d][j][]; if(k-t>eps)
{
x=;
t=k;
s1=dp[a-][b][c][d][j][];
s2=dp[a-][b][c][d][j][];
s3=dp[a-][b][c][d][j][];
}
else
if(fabs(k-t)<eps)
{
x++;
s1+=dp[a-][b][c][d][j][];
s2+=dp[a-][b][c][d][j][];
s3+=dp[a-][b][c][d][j][];
}
} if(b)
{
dfs(a,b-,c,d,j);
double k=dp[a][b-][c][d][j][]; if(k-t>eps)
{
x=;
t=k;
s1=dp[a][b-][c][d][j][];
s2=dp[a][b-][c][d][j][];
s3=dp[a][b-][c][d][j][];
}
else
if(fabs(k-t)<eps)
{
x++;
s1+=dp[a][b-][c][d][j][];
s2+=dp[a][b-][c][d][j][];
s3+=dp[a][b-][c][d][j][];
}
} if(d)
{
dfs(a,b,c,d-,j);
double k=dp[a][b][c][d-][j][]; if(k-t>eps)
{
x=;
t=k;
s1=dp[a][b][c][d-][j][];
s2=dp[a][b][c][d-][j][];
s3=dp[a][b][c][d-][j][];
}
else
if(fabs(k-t)<eps)
{
x++;
s1+=dp[a][b][c][d-][j][];
s2+=dp[a][b][c][d-][j][];
s3+=dp[a][b][c][d-][j][];
}
}
} if(i==) //Traitor
{
double t=-1.0; if(a)
{
dfs(a-,b,c,d,j);
double k=dp[a-][b][c][d][j][]; if(k-t>eps)
{
x=;
t=k;
s1=dp[a-][b][c][d][j][];
s2=dp[a-][b][c][d][j][];
s3=dp[a-][b][c][d][j][];
}
else
if(fabs(k-t)<eps)
{
x++;
s1+=dp[a-][b][c][d][j][];
s2+=dp[a-][b][c][d][j][];
s3+=dp[a-][b][c][d][j][];
}
} if(b)
{
dfs(a,b-,c,d,j);
double k=dp[a][b-][c][d][j][]; if(k-t>eps)
{
x=;
t=k;
s1=dp[a][b-][c][d][j][];
s2=dp[a][b-][c][d][j][];
s3=dp[a][b-][c][d][j][];
}
else
if(fabs(k-t)<eps)
{
x++;
s1+=dp[a][b-][c][d][j][];
s2+=dp[a][b-][c][d][j][];
s3+=dp[a][b-][c][d][j][];
}
} if(c)
{
dfs(a,b,c-,d,j);
double k=dp[a][b][c-][d][j][]; if(k-t>eps)
{
x=;
t=k;
s1=dp[a][b][c-][d][j][];
s2=dp[a][b][c-][d][j][];
s3=dp[a][b][c-][d][j][];
}
else
if(fabs(k-t)<eps)
{
x++;
s1+=dp[a][b][c-][d][j][];
s2+=dp[a][b][c-][d][j][];
s3+=dp[a][b][c-][d][j][];
}
}
} dp[a][b][c][d][i][]=s1/x;
dp[a][b][c][d][i][]=s2/x;
dp[a][b][c][d][i][]=s3/x;
//printf("%d %d %d %d %d %.3lf %.3lf %.3lf\n",a,b,c,d,i,dp[a][b][c][d][i][0],dp[a][b][c][d][i][1],dp[a][b][c][d][i][2]);
} int main()
{
freopen("hdoj6224.in","r",stdin);
freopen("hdoj6224.out","w",stdout);
int cas;
scanf("%d",&cas); memset(vis,,sizeof(vis)); while(cas--)
{
int A,B,C,D;
scanf("%d%d%d%d",&A,&B,&C,&D);
dfs(A,B,C,D,);
printf("%.6lf %.6lf %.6lf\n",dp[A][B][C][D][][],dp[A][B][C][D][][],dp[A][B][C][D][][]);
}
return ;
}
【HDOJ6224】Legends of the Three Kingdoms(概率DP)的更多相关文章
- Codeforces 28C [概率DP]
/* 大连热身D题 题意: 有n个人,m个浴室每个浴室有ai个喷头,每个人等概率得选择一个浴室. 每个浴室的人都在喷头前边排队,而且每个浴室内保证大家都尽可能均匀得在喷头后边排队. 求所有浴室中最长队 ...
- HDU 4405 Aeroplane chess (概率DP)
题意:你从0开始,要跳到 n 这个位置,如果当前位置是一个飞行点,那么可以跳过去,要不然就只能掷骰子,问你要掷的次数数学期望,到达或者超过n. 析:概率DP,dp[i] 表示从 i 这个位置到达 n ...
- POJ 2096 Collecting Bugs (概率DP)
题意:给定 n 类bug,和 s 个子系统,每天可以找出一个bug,求找出 n 类型的bug,并且 s 个都至少有一个的期望是多少. 析:应该是一个很简单的概率DP,dp[i][j] 表示已经从 j ...
- POJ 2151 Check the difficulty of problems (概率DP)
题意:ACM比赛中,共M道题,T个队,pij表示第i队解出第j题的概率 ,求每队至少解出一题且冠军队至少解出N道题的概率. 析:概率DP,dp[i][j][k] 表示第 i 个队伍,前 j 个题,解出 ...
- 概率DP light oj 1030
t组数据 n块黄金 到这里就捡起来 出发点1 到n结束 点+位置>n 重掷一次 dp[i] 代表到这里的概率 dp[i]=(dp[i-1]+dp[i-2]... )/6 如果满6个的话 否则 ...
- hdu 4050 2011北京赛区网络赛K 概率dp ***
题目:给出1-n连续的方格,从0开始,每一个格子有4个状态,左右脚交替,向右跳,而且每一步的步长必须在给定的区间之内.当跳出n个格子或者没有格子可以跳的时候就结束了,求出游戏的期望步数 0:表示不能到 ...
- [转]概率DP总结 by kuangbin
概率类题目一直比较弱,准备把kuangbin大师傅总结的这篇题刷一下! 我把下面的代码换成了自己的代码! 原文地址:http://www.cnblogs.com/kuangbin/archive/20 ...
- SGU 422 Fast Typing(概率DP)
题目大意 某人在打字机上打一个字符串,给出了他打每个字符出错的概率 q[i]. 打一个字符需要单位1的时间,删除一个字符也需要单位1的时间.在任意时刻,他可以花 t 的时间检查整个打出来的字符串,并且 ...
- HDU 4050 wolf5x(动态规划-概率DP)
wolf5x Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Sub ...
- 概率dp入门
概率DP主要用于求解期望.概率等题目. 转移方程有时候比较灵活. 一般求概率是正推,求期望是逆推.通过题目可以体会到这点. poj2096:Collecting Bugs #include <i ...
随机推荐
- c#自定义类型之间的转换(强制类型转换)
public class ResultModel { public string PlateNumber { get; set; } public int PlateColor { get; set; ...
- Bootstrap 页面标题(Page Header)
Bootstrap页面标题(PageHeader)是个不错功能,它会网页的标题的四周添加适当的间距,当一个网页中有多个标题并且每个标题之间需要添加一定适当的间距,使用页面标题是非常有用的.如果需要使用 ...
- 解决cocos2dx 3.x 导入cocostudio的ui界面出现错位问题
笔者今天发现导入cocostudio的ui界面时,会有部分控件出现错位的现象,后来我看了一下源码,发现是部分控件是没有继承 Layout类,导致不能设置控件位置造成,原因可以看看cocos2dx 源码 ...
- 洛谷 1486/BZOJ 1503 郁闷的出纳员
1503: [NOI2004]郁闷的出纳员 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 13866 Solved: 5069[Submit][Stat ...
- 【Git版本控制】Git的merge合并分支命令
1.实例 git checkout master git merge dev merge合并分支只对当前分支master产生影响,被合并的分支dev不受影响. 假设你有两个分支,“stable” 和 ...
- 第一本C语言笔记(下)
11. 数组 (1)数组初始化时,如果初始化数字个数超过存储区个数,就忽略多余数字.如果初始化数字个数少于存储区个数,则后面的存储区自动被初始化为0. (2)数组名称可以代表数组里第一个存储区的地址. ...
- Java-JFrame窗体美化
Java-JFrame窗体美化 JFrame默认的窗体比较土,可以通过一定的美化,让窗体表现的比较漂亮,具体要根据设计的设计图进行美化: JFrame美化的大致思路:先将JFrame去除默认美化效果, ...
- 事务控制语言DTL
一.什么是事务? · 数据库中的事务,是指可以将“多条相关语句执行”看做是“一条语句执行”的一种内部机制.即事务是一种可以保证“多条语句一次性执行完成”或者一条语句都不执行的机制. 三.事务的特点 原 ...
- 15.Yii2.0框架where单表查询
目录 新建控制器 HomeController.php 新建model article.php 新建控制器 HomeController.php D:\xampp\htdocs\yii\control ...
- PAT Basic 1073
1073 多选题常见计分法 批改多选题是比较麻烦的事情,有很多不同的计分方法.有一种最常见的计分方法是:如果考生选择了部分正确选项,并且没有选择任何错误选项,则得到 50% 分数:如果考生选择了任何一 ...