HDU 4089
很容易列出方程
设dp[i][j]为排在第i位置,总共有j个人排队到达目标状态的概率
i=1
dp[i][j]=p4+p1*dp[i][j]+p2*dp[j][j]
2<=i<=k
dp[i][j]=p4+p1*dp[i][j]+p2*dp[i-1][j]+p3*dp[i-1][j-1]
i>k
dp[i][j]=p1*dp[i][j]+p2*dp[i-1][j]+p3*dp[i-1][j-1]
设p2=p2/(1-p1),p3=p3/(1-p1),p4=p4/(1-p4)
上述三个转移方程化简后为
dp[i][j]=p2*dp[i-1][j]+p3*dp[i-1][j-1] i>k
dp[i][j]=p4+p2*dp[i-1][j]+p3*dp[i-1][j-1] 2<=i<=k
dp[i][j]=p4+p2*dp[j][j] i==1
可以发现同一列的各状态存在一个环的依赖状态,于是,可以先求出dp[j][j]
不妨设dp[i][j]=A[i]*dp[j][j]+B[i]
不停地往上代入,即可得到最终dp[j][j]的表达式了
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm> using namespace std; double p[2050][2050];
double A[2050],B[2050]; int main(){
int n,m,k,k0,k1;
double p1,p2,p3,p4;
while(scanf("%d%d%d%lf%lf%lf%lf",&n,&m,&k,&p1,&p2,&p3,&p4)!=EOF){
if(p4<1e-5){
printf("0.00000\n");
continue;
}
// cout<<"YES"<<endl;
p[1][1]=p4/(1-p1-p2);
p2=p2/(1-p1); p3=p3/(1-p1); p4=p4/(1-p1);
for(int j=2;j<=n;j++){
for(int i=1;i<=j;i++){
if(i==1){
A[1]=p2; B[1]=p4;
}
else if(i>=2&&i<=k){
A[i]=A[i-1]*p2;
B[i]=p4+p3*p[i-1][j-1]+p2*B[i-1];
}
else{
A[i]=p2*A[i-1];
B[i]=p2*B[i-1]+p3*p[i-1][j-1];
}
}
p[j][j]=B[j]/(1-A[j]);
for(int i=1;i<=j-1;i++){
if(i==1){
p[1][j]=p4+p2*p[j][j];
}
else if(i>=2&&i<=k){
p[i][j]=p4+p2*p[i-1][j]+p3*p[i-1][j-1];
}
else
p[i][j]=p2*p[i-1][j]+p3*p[i-1][j-1];
}
}
printf("%.5lf\n",p[m][n]);
}
return 0;
}
HDU 4089的更多相关文章
- HDU 4089 Activation 概率DP 难度:3
http://acm.hdu.edu.cn/showproblem.php?pid=4089 这道题中一共有两个循环: 1.事件1 如果一直落在Activation failed事件上,那么就会重新继 ...
- HDU 4089 Activation:概率dp + 迭代【手动消元】
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4089 题意: 有n个人在排队激活游戏,Tomato排在第m个. 每次队列中的第一个人去激活游戏,有可能 ...
- HDU 4089 Activation(概率DP)(转)
11年北京现场赛的题目.概率DP. 公式化简起来比较困难....而且就算结果做出来了,没有考虑特殊情况照样会WA到死的.... 去参加区域赛一定要考虑到各种情况. 像概率dp,公式推出来就很容易写 ...
- HDU 4089 && UVa 1498 Activation 带环的概率DP
要在HDU上交的话,要用滚动数组优化一下空间. 这道题想了很久,也算是想明白了,就好好写一下吧. P1:激活游戏失败,再次尝试. P2:连接失服务器败,从队首排到队尾. P3:激活游戏成功,队首的人出 ...
- [HDU 4089]Activation[概率DP]
题意: 有n个人排队等着在官网上激活游戏.Tomato排在第m个. 对于队列中的第一个人.有以下情况: 1.激活失败,留在队列中等待下一次激活(概率为p1) 2.失去连接,出队列,然后排在队列的最后( ...
- Activation HDU - 4089(概率dp)
After 4 years' waiting, the game "Chinese Paladin 5" finally comes out. Tomato is a crazy ...
- hdu 4089 概率dp
/* 题目大意:注册一款游戏需要排队,一共有四种事件: 1.注册失败,队列不变,概率为p1 2.注册过程中断开连接,正在注册的人排到队列的末尾,概率为p2 3.注册成功,移出队列,概率为p3 4.服务 ...
- Activation(hdu 4089)
题目:仙5的激活序列.有以下4种情况: 1.注册失败,但是不影响队列顺序 ,概率为p1 2.连接失败,队首的人排到队尾,概率为p2 3.注册成功,队首离开队列,概率为p3 4.服务器崩溃,激活停止,概 ...
- Activation HDU - 4089 (概率DP)
kuangbin的博客 强 #include <bits/stdc++.h> using namespace std; const int MAXN = 2005; const doubl ...
随机推荐
- OpenLayers学习笔记3——使用jQuery UI美化界面设计
PC端软件在开发是有较多的界面库能够选择,比方DevExpress.BCG.DotNetBar等,能够非常方便快捷的开发出一些炫酷的界面,近期在学习OpenLayers.涉及到web前端开发,在设计界 ...
- vehicle time series data analysis
以HADOOP为代表的云计算提供的仅仅是一个算法执行环境,为大数据的并行计算提供了在现有软硬件水平下最好的(近似)方法.并不能解决大数据应用中的全部问题.从详细应用而言,通过物联网方式接入IT圈的数据 ...
- ASPX和Razor
ASPX ASPX文件是微软的在server端运行的动态网页文件,通过IIS解析运行后能够得到动态页面,是微软推出的一种新的网络编程方法,而不是ASP的简单升级,由于它的编程方法和ASP有非常大的不同 ...
- 【UML】UML世界的构成
UML概述 全名:Unified Modeling Language 中文名:统一建模语言 发展历程:"始于1997年一个OMG标准.它是一个支持模型化和软件系统开发的图形化语言,为软件开发 ...
- JAVA项目中公布WebService服务——简单实例
1.在Java项目中公布一个WebService服务: 怎样公布? --JDK1.6中JAX-WS规范定义了怎样公布一个WebService服务. (1)用jdk1.6.0_21以后的版本号公布. ( ...
- Light OJ 1288 Subsets Forming Perfect Squares 高斯消元求矩阵的秩
题目来源:Light OJ 1288 Subsets Forming Perfect Squares 题意:给你n个数 选出一些数 他们的乘积是全然平方数 求有多少种方案 思路:每一个数分解因子 每隔 ...
- java 基本数据类型及自己主动类型提升
基本数据类型:8种 1.整型: byte 1个字节 8位 -128到127 short 2个字节 16位 -2^15到(2^15)-1 int 4个字节 32 ...
- Node.js:连接 MySQL
ylbtech-Node.js:连接 MySQL 1.返回顶部 1. Node.js 连接 MySQL 本章节我们将为大家介绍如何使用 Node.js 来连接 MySQL,并对数据库进行操作. 如果你 ...
- sql server 随机生成布尔值
) AS BIT) 或者 )
- 关于flex布局中的兼容性问题
这几天在做项目中用到了flex布局,但是在测试的过程中发现他的兼容性实在是太差了,仅仅用到水平和垂直居中的样式,没想到兼容性代码就写了好几行. display:flex; display:-webki ...