luoguP3239 [HNOI2015]亚瑟王 概率期望DP
当初怎么想的来着.....又忘了......
首先,总期望 = 每张卡片的期望之和
求期望,只要我们求出每张卡片被用掉的概率即可
如果直接上状态$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的更多相关文章
- BZOJ4008 : [HNOI2015]亚瑟王(期望dp)
题意 略(看了20min才看懂...) 题解 我一开始天真地一轮轮推期望,发现根本不好算... 唉~ 不会做就只能抄题解咯 看了一波DOFY大佬的解法qwq 发现有句神奇的话 记住,期望要倒着推... ...
- 洛谷P3239 [HNOI2015]亚瑟王(期望dp)
传送门 stdcall大佬好强 期望的姿势不是很高……据大佬说期望有一个线性性质,也就是说可以把每一张牌的期望伤害算出来然后再加起来就是总的期望伤害 因为每一张牌只能用一次,我们设$dp[i]$表示第 ...
- 洛谷 P3239 [HNOI2015]亚瑟王(期望+dp)
题面传送门 感觉是道挺好的题,可惜当时没写题解来着的? 根据期望的线性公式,我们求出每个卡牌被发动的概率 \(q_i\),然后 \[ans=\sum\limits_{i=1}^np_id_i \] 于 ...
- bzoj4008: [HNOI2015]亚瑟王【期望dp】
一个特别神奇的dp,特别厉害. f(i, j) 表示 有 j 轮发动技能的牌在 [1, i] 另外的m - j轮在[i + 1, n]之间的概率. 怎么转移呢? 首先考虑i这张牌不选的情况,f(i - ...
- 【洛谷3239_BZOJ4008】[HNOI2015] 亚瑟王(期望 DP)
题目: 洛谷 3239 分析: 卡牌造成的伤害是互相独立的,所以 \(ans=\sum f_i\cdot d_i\) ,其中 \(f_i\) 表示第 \(i\) 张牌 在整局游戏中 发动技能的概率.那 ...
- P3239 [HNOI2015]亚瑟王——概率DP
题面:亚瑟王 最近考试考期望很自闭啊,没做过这种类型的题,只能现在练一练: 所谓期望,就是状态乘上自己的概率:对于这道题来说,我们要求的是每张牌的伤害乘上打出的概率的和: 当然不是直接乘,因为给的是每 ...
- 【bzoj4008】[HNOI2015]亚瑟王 概率dp
题目描述 $n$ 张牌,$r$ 轮游戏,每轮从左向右操作,遇到第 $i$ 张牌有 $p_i$ 的概率选中,选中会产生 $d_i$ 的贡献,丢弃掉该牌并结束这一轮,否则继续下一张.问最终的期望贡献. 输 ...
- 【BZOJ-4008】亚瑟王 概率与期望 + DP
4008: [HNOI2015]亚瑟王 Time Limit: 20 Sec Memory Limit: 512 MBSec Special JudgeSubmit: 832 Solved: 5 ...
- 概率DP——BZOJ4008 [HNOI2015]亚瑟王
[HNOI2015]亚瑟王 Description 小 K 不慎被 LL 邪教洗脑了,洗脑程度深到他甚至想要从亚瑟王邪教中脱坑.他决定,在脱坑之前,最后再来打一盘亚瑟王.既然是最后一战,就一定要打得漂 ...
随机推荐
- 【BZOJ】3039: 玉蟾宫 悬线法
[题意]给定01矩阵,求最大全1子矩阵.n,m<=1000. [算法]动态规划(悬线法) [题解]★对于01矩阵中的任意一个全1极大子矩阵,都可以在其上边界遇到的障碍点处悬线到下边界的点x,则点 ...
- JavaScript使用数组
for循环遍历 //js的数组里可以存各种类型 var arr =[1,5,true,false,'小明']; //遍历 for(var i=0;i<arr.length;i++){ alert ...
- Xcode变量概览-summary
问题描述 在Xcode中断点调试时,鼠标停留在变量上,就能看到变量的信息.但对于自定义对象,通常Xcode提供的直接信息非常有限,像这样 想要了解这个对象具体的内容,需要展开左边的箭头 当开发者想要知 ...
- Vue 使用自定义组件时报错:Uncaught TypeError: Cannot assign to read only property 'exports' of object '#<Object>'
自己试做了一下vue的插件 参考element-ui: 写了一个组件 import message from './packages/message/index.js'; const install ...
- solr笔记之安装部署到tomcat
1. 下载 solr 去官网下载,下载的时候选清华的镜像源,这个页面:https://mirrors.tuna.tsinghua.edu.cn/apache/lucene/solr/7.1.0/ 在/ ...
- NB二人组(一)----堆排序
堆排序前传--树与二叉树简介 特殊且常用的树--二叉树 两种特殊的二叉树 二叉树的存储方式 二叉树小结 堆排序 堆这个玩意....... 堆排序过程: 构造堆: 堆排序的算法程序(程序需配合着下图理 ...
- oracle数据库的date和timestamp类型
1.date类型存储数据的格式为年月日时分秒,可以精确到秒 timestamp类型存储数据的格式为年月日时分秒,可以精确到纳秒(9位) 2.date类型 Date类型的数据可以显示到年月日,也可以显示 ...
- perl6 单线程破解phpmyadmin脚本
use HTTP::UserAgent; my $ua = HTTP::UserAgent.new; my $url = 'http://localhost/phpMyAdmin/index.php' ...
- Windows 7 64 位操作系统安装 Ubuntu 17.10
一.准备工作 1. DiskGenius:分区工具,为 Linux 建立单独的分区.(Linux 公社下载源) 2. UUI:Universal USB Installer,通用 U 盘安装器,用来制 ...
- 64_t1
TOPCOM-0.17.8-2.fc26.x86_64.rpm 13-Feb-2017 22:09 269054 TOPCOM-devel-0.17.8-2.fc26.i686.rpm 13-Feb- ...