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

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

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

如果直接上状态$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. 写一个简易浏览器、ASP.NET核心知识(3)

    前言 先在文章前面说好了,省得大家发现我根本没有这样的头发,duang的一下一堆人骂我. 这篇文章的标题有点大,其实挺low的,我需要在开头解释一下.我这里只想写一个小的控制台,旨在模拟浏览器的htt ...

  2. from 表单多文本提交不为空

    假设需要提交4个文本,均不为空: <form id="form" onsubmit="return check()"> </form> ...

  3. HDU 3790 最短生成树 (最短路)

    题目链接 Problem Description 给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的. ...

  4. webgote的例子(5)Sql注入(Blog)

    SQL Injection - Stored (Blog) (本章内容):留言板的注入 看到这个页面先看以下这个页面是做什么的.进行正常的写入发现我每写一句话,其内容都会写到下面的entry里面 在尝 ...

  5. 64_t3

    texlive-dice-svn28501.0-33.fc26.2.noarch.rpm 24-May-2017 15:52 36490 texlive-dichokey-doc-svn17192.0 ...

  6. 调用HTMLTestRunner生产的报告内容为空解决办法

    开始代码如下,生成报告内容为空: #coding=utf-8 import unittest,time,reimport requestsimport jsonimport HTMLTestRunne ...

  7. WebAPI使用Swagger生成接口文档

    开发工具:VS2017 版本15.7.1 新建项目,选择空模板,下面只勾选WebAPI 配置Web.config <system.webServer> 节点改为 <system.we ...

  8. Mybatis的初步使用

    MyBatis 是当下最流行的持久层框架,也是ORM框架,本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation 迁移到了google ...

  9. Windows 和Linux 误删除后的恢复

    ext文件系统上删除文件,可以恢复:extundelete; windows 恢复删除文件: final data v2.0汉化版 和 easyrecovery

  10. Linux命令参数处理 shell脚本函数getopts

    getopts 命令 用途 处理命令行参数,并校验有效选项. 语法 getopts 选项字符串 名称 [ 参数 ...] 描述 getopts 的设计目标是在循环中运行,每次执行循环,getopts ...