当初怎么想的来着.....又忘了......

首先,总期望 = 每张卡片的期望之和

求期望,只要我们求出每张卡片被用掉的概率即可

如果直接上状态$f[i][j]$表示在第$i$轮中,第$j$张牌发动的概率

可以发现转移很困难......然而作死的我还是写了一个,$f[i][j] = \prod_{k = 1}^{j - 1} (1 - f[i][k])(1 - \sum\limits_{k = 1}^{i - 1} f[k][j])p[j]$

嗯.........复杂度$O(Tnr)$看起来很靠谱,然而由于存在大量前置状态的干扰,完全无法确定是不是正确的.......

所以还是换一种思路吧..............

可以发现,考虑一局游戏中一张牌发动的概率

那么,如果考虑每一局它发动的概率,那么这是一个“或”概率,肯定不好求

因此,我们考虑反面,每一局它都不发动的概率,求“与”概率

那么,对于牌$i$而言,它一局不发动的概率跟(有多少轮它可以选择发动与否)有关

也就是说,第$i$张牌不发动的概率跟前面有多少张牌发动了有关

因此,自然地设出状态$f[i][j]$表示前$i$张牌中,还有$j$张牌没有被打出的概率

转移很简单,考虑第$i $张牌有没有被发动

$f[i][j] += f[i - 1][j] *(1 - p[i])^j$(不发动)

$f[i][j] += f[i - 1][j + 1] * (1 - (1 - p[i])^{j + 1})$(发动)

最后求$i$的期望的时候,把所有的$f[i][j]$加权之后统计即可

即$E[i] = \sum\limits_{j = 1}^{r} f[i][j] * (1 - (1 - p[i]) ^ j) * v[i]$

注意预处理一下幂即可

复杂度$O(Tnr)$

#include <cstdio>
#include <cstring>
#define dl double
#define ri register int
#define sid 505
using namespace std; char c;
int n, m, T, d[sid];
dl ans;
dl p[sid], dp[sid][sid]; #define getchar() *S ++
char RR[], *S = RR;
inline int read() {
int p = ; c = getchar();
while(c > '' || c < '') c = getchar();
while(c >= '' && c <= '') { p = p * + c - ''; c = getchar(); }
return p;
} inline dl dread() {
int p1 = read(); if(c != '.') return (dl)p1;
dl p2 = , p3 = 0.1; c = getchar();
while(c >= '' && c <= '')
p2 += (c - '') * p3, p3 *= 0.1, c = getchar();
return p2 + (dl)p1;
} int main() {
fread(RR, , sizeof(RR), stdin);
T = read();
for(ri t = ; t <= T; t ++) {
n = read(); m = read();
for(ri i = ; i <= n; i ++)
p[i] = dread(), d[i] = read(), p[i] = 1.0 - p[i];
ans = 0.0; p[] = 1.0;
dp[][m] = 1.0;
for(ri i = ; i <= n; i ++) {
dp[i][m + ] = ;
dl pi = p[i - ], pp = p[i - ];
dl np = p[i], tp = p[i];
for(ri j = ; j <= m; j ++) {
dp[i][j] = dp[i - ][j] * pp; pp *= pi;
dp[i][j] += dp[i - ][j + ] * (1.0 - pp);
ans += dp[i][j] * (1.0 - tp) * (dl)d[i];
tp *= np;
}
}
dp[][m] = 0.0;
printf("%.10lf\n", ans);
}
return ;
}

luoguP3239 [HNOI2015]亚瑟王 概率期望DP的更多相关文章

  1. BZOJ4008 : [HNOI2015]亚瑟王(期望dp)

    题意 略(看了20min才看懂...) 题解 我一开始天真地一轮轮推期望,发现根本不好算... 唉~ 不会做就只能抄题解咯 看了一波DOFY大佬的解法qwq 发现有句神奇的话 记住,期望要倒着推... ...

  2. 洛谷P3239 [HNOI2015]亚瑟王(期望dp)

    传送门 stdcall大佬好强 期望的姿势不是很高……据大佬说期望有一个线性性质,也就是说可以把每一张牌的期望伤害算出来然后再加起来就是总的期望伤害 因为每一张牌只能用一次,我们设$dp[i]$表示第 ...

  3. 洛谷 P3239 [HNOI2015]亚瑟王(期望+dp)

    题面传送门 感觉是道挺好的题,可惜当时没写题解来着的? 根据期望的线性公式,我们求出每个卡牌被发动的概率 \(q_i\),然后 \[ans=\sum\limits_{i=1}^np_id_i \] 于 ...

  4. bzoj4008: [HNOI2015]亚瑟王【期望dp】

    一个特别神奇的dp,特别厉害. f(i, j) 表示 有 j 轮发动技能的牌在 [1, i] 另外的m - j轮在[i + 1, n]之间的概率. 怎么转移呢? 首先考虑i这张牌不选的情况,f(i - ...

  5. 【洛谷3239_BZOJ4008】[HNOI2015] 亚瑟王(期望 DP)

    题目: 洛谷 3239 分析: 卡牌造成的伤害是互相独立的,所以 \(ans=\sum f_i\cdot d_i\) ,其中 \(f_i\) 表示第 \(i\) 张牌 在整局游戏中 发动技能的概率.那 ...

  6. P3239 [HNOI2015]亚瑟王——概率DP

    题面:亚瑟王 最近考试考期望很自闭啊,没做过这种类型的题,只能现在练一练: 所谓期望,就是状态乘上自己的概率:对于这道题来说,我们要求的是每张牌的伤害乘上打出的概率的和: 当然不是直接乘,因为给的是每 ...

  7. 【bzoj4008】[HNOI2015]亚瑟王 概率dp

    题目描述 $n$ 张牌,$r$ 轮游戏,每轮从左向右操作,遇到第 $i$ 张牌有 $p_i$ 的概率选中,选中会产生 $d_i$ 的贡献,丢弃掉该牌并结束这一轮,否则继续下一张.问最终的期望贡献. 输 ...

  8. 【BZOJ-4008】亚瑟王 概率与期望 + DP

    4008: [HNOI2015]亚瑟王 Time Limit: 20 Sec  Memory Limit: 512 MBSec  Special JudgeSubmit: 832  Solved: 5 ...

  9. 概率DP——BZOJ4008 [HNOI2015]亚瑟王

    [HNOI2015]亚瑟王 Description 小 K 不慎被 LL 邪教洗脑了,洗脑程度深到他甚至想要从亚瑟王邪教中脱坑.他决定,在脱坑之前,最后再来打一盘亚瑟王.既然是最后一战,就一定要打得漂 ...

随机推荐

  1. 【IIS】IIS中同时满足集成模式和经典模式

    手里有一个项目--系统设置(主要功能是对系统一些字典表的设置.权限管理等功能).在VS上运行没有任何问题.可是发布到IIS上之后,报黄页. 发布后程序运行环境为: windows 7 32位 IIS为 ...

  2. 51nod1149 Pi的递推式

    基准时间限制:1 秒 空间限制:131072 KB 分值: 640 F(x) = 1 (0 <= x < 4) F(x) = F(x - 1) + F(x - pi) (4 <= x ...

  3. 下载Google My Tracks

    http://code.google.com/p/mytracks/source/browse/?name=2.0.2#hg%2FMyTracks%253Fstate%253Dclosed 需要类似的 ...

  4. hdu 5328 Problem Killer(杭电多校赛第四场)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5328 题目大意:找到连续的最长的等差数列or等比数列. 解题思路:1.等差等比的性质有很多.其中比较重 ...

  5. javascript复习笔记

    /* Javascript:用来在页面中编写特效,和HTML.CSS一样都是有浏览器解析 Javascript语言: 一.JS如何运行(javascript,jscript,vbscript,appl ...

  6. 用CRF做命名实体识别(一)

    用CRF做命名实体识别(二) 用CRF做命名实体识别(三) 用BILSTM-CRF做命名实体识别 博客园的markdown格式可能不太方便看,也欢迎大家去我的简书里看 摘要 本文主要讲述了关于人民日报 ...

  7. 【IDEA】与Eclipse "Link with Editor"等价功能设置

    Link With Editor是Eclipse内置功能中十分小巧,但却异常实用的一个功能.这个开关按钮 (Toggle Button) 出现在各式导航器视图 ( 例如 Resource Explor ...

  8. 74.VS2013和opencv3.1.0安装教程

    一.先下载文件 1.VS2013 VS2013有很多版本,专业版,旗舰版,中文英文之类的,所对应的密钥也不一样.我选择的是简体中文专业版.下载链接如下. http://www.musnow.com/t ...

  9. HDU 6198 2017沈阳网络赛 线形递推

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6198 题意:给出一个数k,问用k个斐波那契数相加,得不到的数最小是几. 解法:先暴力打表看看有没有规律 ...

  10. 「caffe编译bug」 undefined reference to `boost::match_results<__gnu_cxx::__normal_iterator<char const*, std::__cxx11

    CXX/LD -o .build_release/tools/test_net.binCXX/LD -o .build_release/tools/convert_annoset.binCXX/LD ...