hdu3076—概率dp

标签 : 概率dp


题目链接

  • 题意:

    2个人分别有AB的血数,轮流扔骰子,数小的自减一血,平的不变,谁先到减0, 谁输,问A赢的概率。
  • 题解:

    dp[i][j]表示的是第一个人有i血,第二个人有j个血的时候1赢的概率。转移方程,假设p1是每一剧中第一个人赢的概率,p2是第二个人赢的概率,dp[i][j] 转化到dp[i-2][j]的概率是p2,dp[i][j]转化到dp[i][j-1]的概率是p1,那么 \(dp[i][j] = d[i-1][j]*p2+dp[i][j-1]*p1;\)
  • 注意事项:

    1. 因为是概率的问题,所以要考虑精度的问题,所以一般定义状态的时候就直接把dp[n][m]定义成最后的结果,不然如果最后的结果需要相加或者别的形式运算才能得到的话很有可能有精度的问题,刚开始定义dp[i][j]表示第一个人失去i格血,第二个人失去j格血的概率;

    2. 这个题一定是个脑残出的,m和n的输入是反的,而且输入并不保证输入的赢的概率和平的概率还有输的概率加起来等于1

    3. 这个题要注意要进行一次概率转化。通过概率转化排除平局的概率对答案的影响。
  • ac 代码和错误代码
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 2008;
double dp[N][N];//dp[i][j]表示的是第一个人有i血,第二个人有j个血的时候1赢的概率。
double a[6],b[6];
int main()
{
int n, m;
while(~scanf("%d%d",&m,&n))
{
for(int i = 0; i < 6; i++) scanf("%lf",&a[i]);
for(int j = 0; j < 6; j++) scanf("%lf",&b[j]);
double p1, p2, ping;
p1 = p2 = ping = 0; for(int i = 0; i < 6; i++){
for(int j = 0; j <= 6; j++){
//if(i==j) ping += a[i]*b[j];
if(i>j)
p1 += a[i]*b[j];
else if(i<j)
p2 +=a[i]*b[j];
}
}
// p2 = 1-p1-ping;
double tm = p1+p2;
p1 = p1/tm;
p2 = p2/tm;
//printf("%lf %lf %lf\n",p1,p2,ping);
for(int i = 0; i <= m; i++) dp[0][i] = 0;
for(int j = 0; j <= n; j++) dp[j][0] = 1;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= m; j++){
dp[i][j] = dp[i-1][j]*p2+dp[i][j-1]*p1;
}
}
printf("%lf\n",dp[n][m]);
}
return 0;
} /* //下面是错误的代码,因为想一下其实每次得到的不是最后的解,那么精度会有很大问题
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = 2008;
double dp[N][N];//dp[i][j]表示第一个人失去i格血,第二个人失去j格血的时候1赢的概率;
double a[6],b[6];
int main()
{
int n,m;
while(~scanf("%d%d",&n,&m))
{
for(int i = 0; i < 6; i++) scanf("%lf",&a[i]);
for(int i = 0; i < 6; i++) scanf("%lf",&b[i]);
double p = 0;
double p2 = 0;
double ping = 0;
for(int i = 0; i < 6; i++){
for(int j = 0; j < i; j++){
if(i==j) ping = a[i]*b[j];
else
p += a[i]*b[j];
}
}
p2 = 1-p-ping;
// printf("%lf %lf\n",p,p2);
// memset(dp,0,sizeof(dp));
for(int i = 0;i <= n; i++){
for(int j = 0; j <= m; j++)
dp[i][j] = 1;
}
dp[0][1] = p;
dp[1][0] = p2;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= m; j++){
dp[i][j] = dp[i-1][j]*p2+dp[i][j-1]*p;
}
}
double ans = 0;
for(int i = 0; i < n; i++){
ans*=dp[i][m];
}
printf("%lf\n",ans);
}
return 0;
}
*/

hdu3076—概率dp的更多相关文章

  1. Codeforces 28C [概率DP]

    /* 大连热身D题 题意: 有n个人,m个浴室每个浴室有ai个喷头,每个人等概率得选择一个浴室. 每个浴室的人都在喷头前边排队,而且每个浴室内保证大家都尽可能均匀得在喷头后边排队. 求所有浴室中最长队 ...

  2. HDU 4405 Aeroplane chess (概率DP)

    题意:你从0开始,要跳到 n 这个位置,如果当前位置是一个飞行点,那么可以跳过去,要不然就只能掷骰子,问你要掷的次数数学期望,到达或者超过n. 析:概率DP,dp[i] 表示从 i  这个位置到达 n ...

  3. POJ 2096 Collecting Bugs (概率DP)

    题意:给定 n 类bug,和 s 个子系统,每天可以找出一个bug,求找出 n 类型的bug,并且 s 个都至少有一个的期望是多少. 析:应该是一个很简单的概率DP,dp[i][j] 表示已经从 j ...

  4. POJ 2151 Check the difficulty of problems (概率DP)

    题意:ACM比赛中,共M道题,T个队,pij表示第i队解出第j题的概率 ,求每队至少解出一题且冠军队至少解出N道题的概率. 析:概率DP,dp[i][j][k] 表示第 i 个队伍,前 j 个题,解出 ...

  5. 概率DP light oj 1030

    t组数据 n块黄金 到这里就捡起来 出发点1 到n结束  点+位置>n 重掷一次 dp[i] 代表到这里的概率 dp[i]=(dp[i-1]+dp[i-2]... )/6  如果满6个的话 否则 ...

  6. hdu 4050 2011北京赛区网络赛K 概率dp ***

    题目:给出1-n连续的方格,从0开始,每一个格子有4个状态,左右脚交替,向右跳,而且每一步的步长必须在给定的区间之内.当跳出n个格子或者没有格子可以跳的时候就结束了,求出游戏的期望步数 0:表示不能到 ...

  7. [转]概率DP总结 by kuangbin

    概率类题目一直比较弱,准备把kuangbin大师傅总结的这篇题刷一下! 我把下面的代码换成了自己的代码! 原文地址:http://www.cnblogs.com/kuangbin/archive/20 ...

  8. SGU 422 Fast Typing(概率DP)

    题目大意 某人在打字机上打一个字符串,给出了他打每个字符出错的概率 q[i]. 打一个字符需要单位1的时间,删除一个字符也需要单位1的时间.在任意时刻,他可以花 t 的时间检查整个打出来的字符串,并且 ...

  9. HDU 4050 wolf5x(动态规划-概率DP)

    wolf5x Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Sub ...

随机推荐

  1. 小白的Python之路 day4 迭代器

    迭代器 学习前,我们回想一下可以直接作用于for循环的数据类型有以下几种: 1.集合数据类型,如list.tuple.dict.set.str等: 2.是generator,包括生成器和带yield的 ...

  2. JS画几何图形之一【直线】

    JS画图的想法经过大脑的时候,觉得有点意思,所以就实践了一番.JS画图为系列文章,本是讲点.线和面 先看样例:http://www.zhaojz.com.cn/demo/draw5.html 一.点 ...

  3. 关于vue 框架与后台框架的混合使用的尝试------转载

    这几天我在研究前台框架和后台框架融合的问题,进行了一些尝试; 我前台选择的是 vue,当然也可以选择 react 等其他 mvvm 框架,不过 vue 对于我来说是最熟悉的; 后台话,我选择的是 ph ...

  4. Nginx 错误处理方法: bind() to 0.0.0.0:80 failed

    Nginx 错误处理方法: bind() to 0.0.0.0:80 failed 今天启动window上的nginx总是报错 错误信息是bind() to 0.0.0.0:80 failed (10 ...

  5. 缓存(Cache)

    l如果每次进入页面的时候都查询数据库生成页面内容的话,如果访问量非常大,则网站性能会非常差.而如果只有第一次访问的时候才查询数据库生成页面内容,以后都直接输出内容,则能提高系统性能.这样无论有多少人访 ...

  6. MySQL 的调节和优化的提示

    MySQL 服务器硬件和操作系统调节: 1. 拥有足够的物理内存来把整个InnoDB文件加载到内存中——在内存中访问文件时的速度要比在硬盘中访问时快的多.2. 不惜一切代价避免使用Swap交换分区 – ...

  7. JAVA本地环境启动OOM问题排查

    1.问题描述 每次启动信息报错如下: 2.排查过程 2.1起初怀疑是堆内存不够: 将本地队内存调整由-Xms512M,-Xmx1024M,改成与测试环境相同1536M,还是失败 如上图报错中有noti ...

  8. [编织消息框架][JAVA核心技术]动态代理应用7-IRpcSend实现

    根据设计生成两个接口,IRpcSend send方法返回数据要求包装成QResult对象 public interface IRpcSend { public <T> QResult< ...

  9. DBCC page 数据页 堆 底层数据分布大小计算

    1.行的总大小: Row_Size = Fixed_Data_Size + Variable_Data_Size + Null_Bitmap + 4(4是指行标题开销) 开销定义: Fixed_Dat ...

  10. 扎实基础之从零开始-Nginx集群分布式.NET应用

    1       扎实基础之快速学习Nginx Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行.其特点是占有内存少 ...