HDU 4089 Activation:概率dp + 迭代【手动消元】
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4089
题意:
有n个人在排队激活游戏,Tomato排在第m个。
每次队列中的第一个人去激活游戏,有可能发生以下四种情况:
(1)激活失败,继续留在队首,等待下一次激活。
(2)连接失败,退到队尾。
(3)激活成功,离开队列。
(4)服务器瘫痪。
发生的概率分别为p1,p2,p3,p4。
问你服务器瘫痪时,Tomato的位置<=k的概率。
题解:
表示状态:
dp[i][j] = probability
表示当前还有i个人在排队,Tomato在位置j。在这以及之后服务器瘫痪时,Tomato位置<=k的概率。
找出答案:
ans = dp[n][m]
如何转移:
按着四种情况分别写就好:
(1)j == 1: dp[i][1] = dp[i][1]*p1 + dp[i][i]*p2 + p4
(2)2<=j<=k: dp[i][j] = dp[i][j]*p1 + dp[i][j-1]*p2 + dp[i-1][j-1]*p3 + p4
(3)k<j<=i: dp[i][j] = dp[i][j]*p1 + dp[i][j-1]*p2 + dp[i-1][j-1]*p3
令p21 = p2/(1-p1), p31 = p3/(1-p1), p41 = p4/(1-p1)
化简得:
(1)j == 1: dp[i][1] = dp[i][i]*p21 + p41
(2)2<=j<=k: dp[i][j] = dp[i][j-1]*p21 + dp[i-1][j-1]*p31 + p41
(3)k<j<=i: dp[i][j] = dp[i][j-1]*p21 + dp[i-1][j-1]*p31
边界条件:
dp[1][1] = dp[1][1]*(p1+p2) + p4
解得:dp[1][1] = p4/(1-p1-p2)
然而这并没有结束……
转移的时候显然先枚举i,在枚举j。
可是j在当前的i中,是往两个方向转移的:
dp[i][j]需要用到前面的dp[i][j-1],而dp[i][1]又用到了后面的dp[i][i]……QAQ
所以迭代一下,先解出dp[i][1]:
每一个dp[i][j]都可以表示成 dp[i][j] = p*dp[i][1] + c 的形式。
显然对于最初的dp[i][1]: p = 1, c = 0
对于后面的每一个dp[i][j]: p *= p21, c = c*p21 + dp[i-1][j-1]*p31 + (j<=k)*p41
这样就由前一项的p和c,推出了当前的p和c。
推啊推,直到推出了:dp[i][i] = p*dp[i][1] + c
这时就可以代入解方程了:
代入原来的递推式dp[i][1] = dp[i][i]*p21 + p41中
得到:dp[i][1] = p21*(p*dp[i][1] + c) + p41
解得:dp[i][1] = (p21*c + p41)/(1 - p*p21)
然而还是没有结束……
这题丧病卡空间……所以用滚动数组。
由于转移的时候要用到dp[0][j]的0值,所以第一维MAX_N变成3,i=1,2轮流使用。
这样就好啦~~~
AC Code:
- #include <iostream>
- #include <stdio.h>
- #include <string.h>
- #define MAX_N 2005
- #define cal(x) ((!(x))?0:(2-((x)&1)))
- using namespace std;
- int n,m,k;
- double p1,p2,p3,p4;
- double dp[][MAX_N];
- int main()
- {
- memset(dp,,sizeof(dp));
- while(scanf("%d%d%d%lf%lf%lf%lf",&n,&m,&k,&p1,&p2,&p3,&p4)!=EOF)
- {
- if(p4<1e-)
- {
- printf("0.00000\n");
- continue;
- }
- double p21=p2/(-p1);
- double p31=p3/(-p1);
- double p41=p4/(-p1);
- dp[cal()][]=p4/(-p1-p2);
- for(int i=;i<=n;i++)
- {
- if(i>)
- {
- double p=1.0,c=;
- for(int j=;j<=i;j++)
- {
- p*=p21;
- c=c*p21+dp[cal(i-)][j-]*p31;
- if(j<=k) c+=p41;
- }
- dp[cal(i)][]=(c*p21+p41)/(-p*p21);
- }
- for(int j=;j<=i;j++)
- {
- dp[cal(i)][j]=dp[cal(i)][j-]*p21+dp[cal(i-)][j-]*p31;
- if(j<=k) dp[cal(i)][j]+=p41;
- }
- }
- printf("%.5f\n",dp[cal(n)][m]);
- }
- }
HDU 4089 Activation:概率dp + 迭代【手动消元】的更多相关文章
- [HDU 4089]Activation[概率DP]
题意: 有n个人排队等着在官网上激活游戏.Tomato排在第m个. 对于队列中的第一个人.有以下情况: 1.激活失败,留在队列中等待下一次激活(概率为p1) 2.失去连接,出队列,然后排在队列的最后( ...
- HDU 4089 Activation 概率DP 难度:3
http://acm.hdu.edu.cn/showproblem.php?pid=4089 这道题中一共有两个循环: 1.事件1 如果一直落在Activation failed事件上,那么就会重新继 ...
- 【BZOJ 2337】 2337: [HNOI2011]XOR和路径(概率DP、高斯消元)
2337: [HNOI2011]XOR和路径 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1170 Solved: 683 Description ...
- BZOJ2707 [SDOI2012]走迷宫 【概率dp + tarjan + 高斯消元】
题目 Morenan被困在了一个迷宫里.迷宫可以视为N个点M条边的有向图,其中Morenan处于起点S,迷宫的终点设为T.可惜的是,Morenan非常的脑小,他只会从一个点出发随机沿着一条从该点出发的 ...
- hdu4418(概率dp + 高斯消元)
应该是一个入门级别的题目. 但是有几个坑点. 1. 只选择x能到达的点作为guass中的未知数. 2. m可能大于n,所以在构建方程组时未知数的系数不能直接等于,要+= 3.题意貌似说的有问题,D为- ...
- Activation HDU - 4089(概率dp)
After 4 years' waiting, the game "Chinese Paladin 5" finally comes out. Tomato is a crazy ...
- Activation HDU - 4089 (概率DP)
kuangbin的博客 强 #include <bits/stdc++.h> using namespace std; const int MAXN = 2005; const doubl ...
- HDU 4089 Activation(概率DP)(转)
11年北京现场赛的题目.概率DP. 公式化简起来比较困难....而且就算结果做出来了,没有考虑特殊情况照样会WA到死的.... 去参加区域赛一定要考虑到各种情况. 像概率dp,公式推出来就很容易写 ...
- HDU 4418 Time travel 期望dp+dfs+高斯消元
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4418 Time travel Time Limit: 2000/1000 MS (Java/Othe ...
- HDU 3853LOOPS(简单概率DP)
HDU 3853 LOOPS 题目大意是说人现在在1,1,需要走到N,N,每次有p1的可能在元位置不变,p2的可能走到右边一格,有p3的可能走到下面一格,问从起点走到终点的期望值 这是弱菜做的第 ...
随机推荐
- Vue+原生App混合开发手记#1
项目的大致需求就是做一个App,里面集成各种功能供用户使用,其中涉及到很多Vue的使用方法,单独总结太麻烦,所以通过这几篇笔记来梳理一下.原型图如下: 路由配置 主界面会用到一些原生App方法,比如验 ...
- 玩转JPA(一)---异常:Repeated column in mapping for entity/should be mapped with insert="false" update="fal
近期用JPA遇到这样一个问题:Repeated column in mapping for entity: com.ketayao.security.entity.main.User column: ...
- Cocoa 静态显示一个对话框
M // // form2.m // test_multi_window // // Created by on 23/7/14. // Copyright (c) 2014 EDU. All rig ...
- 配置LANMP环境(10)-- 安装memcached与redis
一.安装memcached 1.安装 yum install memcached 2.设置1G内存 memcached -u memcached -p -m -c -d 3.启动与设置开机自启动 sy ...
- 细细品味大数据--初识hadoop
初识hadoop 前言 之前在学校的时候一直就想学习大数据方面的技术,包括hadoop和机器学习啊什么的,但是归根结底就是因为自己太懒了,导致没有坚持多长时间,加上一直为offer做准备,所以当时重心 ...
- saltstack之nginx部署
1./srv/salt/nginx目录树 . conf.sls file |--- nginx |--- nginx-1.5.1.tar.gz |--- nginx.conf |--- nginx_l ...
- C语言基础知识【循环】
C 循环1.有的时候,我们可能需要多次执行同一块代码.一般情况下,语句是按顺序执行的:函数中的第一个语句先执行,接着是第二个语句,依此类推.编程语言提供了更为复杂执行路径的多种控制结构.循环语句允许我 ...
- python字符串基本方法
字符串类型在Python中是十分重要的类型,他一般用引号中间添加字符的形式表达,不同于其他语言的是,Python中双引号(” “)与单引号(’ ‘)是不予区分的.都可以用来表示字符串 创建.赋值和访问 ...
- 加密php源代码
<?php function RandAbc($length = "") { //返回随机字符串 $str = "ABCDEFGHIJKLMNOPQRSTUVWXY ...
- BAPI LIST
[转自 http://blog.csdn.net/minsenwu/article/details/8432081] 库存管理BAPI 库存: 1. BAPI_MATERIAL_AVAILABILIT ...