UOJ399 CTSC2018 假面 期望、DP
\(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\)一定会存活的情况。
UOJ399 CTSC2018 假面 期望、DP的更多相关文章
- [CTSC2018] 假面 | 期望 DP
		题目链接 LOJ 2552 Luogu P4564 考场上这道题我先是写了个70分暴力,然后发现似乎可以NTT,然鹅问题是--我没学过NTT,遂脑补之,脑补出来了,下午出成绩一看,卡成暴力分(70)- ... 
- [CTSC2018]假面(概率DP)
		考场上以为CTSC的概率期望题都不可做,连暴力都没写直接爆零. 结果出来发现全场70以上,大部分AC,少于70的好像极少,感觉血亏. 设a[i][j]表示到当前为止第i个人的血量为j的概率(注意特判血 ... 
- 【BZOJ-1419】Red is good     概率期望DP
		1419: Red is good Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 660 Solved: 257[Submit][Status][Di ... 
- [NOIP2016]换教室 D1 T3 Floyed+期望DP
		[NOIP2016]换教室 D1 T3 Description 对于刚上大学的牛牛来说, 他面临的第一个问题是如何根据实际情况中情合适的课程. 在可以选择的课程中,有2n节课程安排在n个时间段上.在第 ... 
- HDU 4336 Card Collector (期望DP+状态压缩 或者 状态压缩+容斥)
		题意:有N(1<=N<=20)张卡片,每包中含有这些卡片的概率,每包至多一张卡片,可能没有卡片.求需要买多少包才能拿到所以的N张卡片,求次数的期望. 析:期望DP,是很容易看出来的,然后由 ... 
- 【BZOJ-4008】亚瑟王      概率与期望 + DP
		4008: [HNOI2015]亚瑟王 Time Limit: 20 Sec Memory Limit: 512 MBSec Special JudgeSubmit: 832 Solved: 5 ... 
- 期望dp BZOJ3450+BZOJ4318
		BZOJ3450 概率期望DP f[i]表示到i的期望得分,g[i]表示到i的期望长度. 分三种情况转移: ① s[i]=‘x’:f[i]=f[i-1],g[i]=0 ② s[i]=‘o’:f[i]= ... 
- HDU 4405 期望DP
		期望DP算是第一题吧...虽然巨水但把思路理理清楚总是好的.. 题意:在一个1×n的格子上掷色子,从0点出发,掷了多少前进几步,同时有些格点直接相连,即若a,b相连,当落到a点时直接飞向b点.求走到n ... 
- POJ 2096 【期望DP】
		题意: 有n种选择,每种选择对应m种状态.每种选择发生的概率相等,每种选择中对应的每种状态发生的概率相等. 求n种选择和m种状态中每种至少发生一次的期望. 期望DP好别扭啊.要用倒推的方法. dp[i ... 
随机推荐
- K8s无状态控制器原理介绍
			Pod控制器: ReplicationController:早期K8s只有这一个控制器,但后来发现让这一个来完成所有任务,太复杂.因此被废弃. ReplicaSet: 它用于帮助用户创建指定数量的Po ... 
- 如何将 普通代码变成 java lamband表达式
			public static void main(String[] args) { Map<String, String> map = new HashMap<>(); List ... 
- 【深入学习linux】git的使用
			git的安装 官网下载地址:https://git-scm.com/downloads 安装完成后,还需要最后一步设置,在命令行输入: $ git config --global user.name ... 
- SpatiaLite, load spatial extension first
- wikiquote
			發現了一個很好玩的網站wikiquote,上面有很多引用的句子 比如關於編程語言的說法 https://en.m.wikiquote.org/wiki/Category:Programming_lan ... 
- 946. Validate Stack Sequences
			946. Validate Stack Sequences class Solution { public: bool validateStackSequences(vector<int> ... 
- JS 生成随机字符串 随机颜色
			使用Math.random()生成随机数 0.7489584611780002数字的.toString(n) 将数字转换为 n 进制的字符串 n取值范围(0~36)"0.vbpjw8lipf ... 
- git解决error: The following untracked working tree files would be overwritten by checkout
			在IDEA中进行分支切换时,出现如此错误,导致无法正常切换:error: The following untracked working tree files would be overwritten ... 
- Python - Django - 中间件 process_response
			process_response 函数是执行完 views.py 后执行的函数 process_response 函数有两个参数,一个是 request,一个是 response,response 是 ... 
- 初识内存挂:VirtualNES金手指教程
			一.什么VirtualNES?什么是金手指? VirtualNES是一个NES模拟器,用来运行.nes文件,即在电脑上玩当年小霸王游戏机上的游戏.而它内置了一个简单的Cheat Engine,称之为金 ... 
