博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UOJ399 CTSC2018 假面 期望、DP
阅读量:5360 次
发布时间:2019-06-15

本文共 564 字,大约阅读时间需要 1 分钟。


\(Q \leq 200000 , C \leq 1000 , m_i \leq 100\)……

先考虑如何维护最后一次操作时所有人的血量期望。不难发现我们需要的复杂度是\(O(Qm_i)\)的,所以不难想到一个Easy的DP:设\(f_{i,j}\)表示当前操作结束后第\(i\)个人血量为\(j\)的概率,转移考虑技能是否命中。

然后考虑结界的释放。注意到结界是否释放到每一个人只和TA和其他人是否存活有关,而和血量无关。所以考虑枚举每一个人,在TA存活的前提下再设一个DP:\(g_{i,j}\)表示考虑了前\(i\)个人、有\(j\)个人存活的概率,转移考虑当前考虑的人是否存活。暴力做的话复杂度是\(O(Cn^3)\),无法通过所有数据。

我们考虑是否能够在\(g_{i,j}\)中去掉某一个人的贡献,这样复杂度就可以变成\(O(Cn^2)\)。注意到:将前\(i\)个人的顺序任意打乱,\(g_{i,j}\)的值一定不会变,所以我们考虑如果当前需要删掉第\(x\)个人的贡献,我们就默认第\(x\)个人是当前最后一个做贡献的人,然后通过DP数组把第\(x\)个人的贡献撤销即可。注意特殊判断\(x\)一定会存活的情况。

转载于:https://www.cnblogs.com/Itst/p/11186010.html

你可能感兴趣的文章
搭建ssm过程中遇到的问题集
查看>>
OpenLayers绘制图形
查看>>
tp5集合h5 wap和公众号支付
查看>>
Flutter学习笔记(一)
查看>>
iOS10 国行iPhone联网权限问题处理
查看>>
洛谷 P1991 无线通讯网
查看>>
Codeforces Round #178 (Div. 2) B. Shaass and Bookshelf 【动态规划】0-1背包
查看>>
SparkStreaming 源码分析
查看>>
【算法】—— 随机音乐的播放算法
查看>>
mysql asyn 示例
查看>>
数据库第1,2,3范式学习
查看>>
《Linux内核设计与实现》第四章学习笔记
查看>>
使用iperf测试网络性能
查看>>
Docker 安装MySQL5.7(三)
查看>>
解决VS+QT无法生成moc文件的问题
查看>>
AngularJs练习Demo14自定义服务
查看>>
CF1067C Knights 构造
查看>>
[BZOJ2938] 病毒
查看>>
CSS: caption-side 属性
查看>>
CSS3中box-sizing的理解
查看>>