2018.09.23 bzoj1076: [SCOI2008]奖励关(期望+状压dp)
传送门
一道神奇的期望状压dp。
用f[i][j]f[i][j]f[i][j]表示目前在第i轮已选取物品状态为j,从现在到第k轮能得到的最大贡献。
如果我们从前向后推有可能会遇到不合法的情况。
所以我们从后向前推。
这时怎么处理不合法的情况呢?
如果当前这个状态不具备选择k的条件。
那么说明第i+1轮可能具备。
于是f[i][j]+=f[i+1][j]f[i][j]+=f[i+1][j]f[i][j]+=f[i+1][j]
否则当前具备选k的条件。
所以要么当前轮不选,要么选了从f[i+1][j∣(1<<(k−1))]f[i+1][j|(1<<(k-1))]f[i+1][j∣(1<<(k−1))]转移过来。
代码:
#include<bits/stdc++.h>
using namespace std;
double f[105][1<<16];
int K,n,w[16],ban[16];
int main(){
	scanf("%d%d",&K,&n);
	for(int i=1;i<=n;++i){
		scanf("%d",&w[i]);
		int tmp;
		while(scanf("%d",&tmp)&&tmp)ban[i]|=1<<(tmp-1);
	}
	int up=1<<n;
	for(int i=K;i;--i){
		for(int j=0;j<up;++j){
			for(int k=1;k<=n;++k){
				if((j&ban[k])==ban[k])f[i][j]+=max(f[i+1][j],f[i+1][j|(1<<(k-1))]+w[k]);
				else f[i][j]+=f[i+1][j];
			}
			f[i][j]/=1.0*n;
		}
	}
	printf("%.6lf",f[1][0]);
	return 0;
}
												
											2018.09.23 bzoj1076: [SCOI2008]奖励关(期望+状压dp)的更多相关文章
- BZOJ1076  [SCOI2008]奖励关   【状压dp + 数学期望】
		
1076: [SCOI2008]奖励关 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 3074 Solved: 1599 [Submit][Sta ...
 - BZOJ1076: [SCOI2008]奖励关【状压DP+期望DP】
		
Description 你正在玩你最喜欢的电子游戏,并且刚刚进入一个奖励关.在这个奖励关里,系统将依次随机抛出k次宝物, 每次你都可以选择吃或者不吃(必须在抛出下一个宝物之前做出选择,且现在决定不吃的 ...
 - BZOJ_1076_[SCOI2008]奖励关_状压DP
		
BZOJ_1076_[SCOI2008]奖励关_状压DP 题意: 你正在玩你最喜欢的电子游戏,并且刚刚进入一个奖励关.在这个奖励关里,系统将依次随机抛出k次宝物, 每次你都可以选择吃或者不吃(必须在抛 ...
 - 【BZOJ】1076: [SCOI2008]奖励关(状压dp+数学期望)
		
http://www.lydsy.com/JudgeOnline/problem.php?id=1076 有时候人蠢还真是蠢.一开始我看不懂期望啊..白书上其实讲得很详细的,什么全概率,全期望(这个压 ...
 - 【BZOJ1076】[SCOI2008] 奖励关(状压DP)
		
点此看题面 大致题意:总共有\(n\)个宝物和\(k\)个回合,每个回合系统将随机抛出一个宝物(抛出每个宝物的概率皆为\(1/n\)),吃掉一个宝物可以获得一定的积分(积分可能为负),而吃掉某个宝物有 ...
 - bzoj 1076: [SCOI2008]奖励关【状压dp+概率dp】
		
设f[i][s]为前i步,选的礼物集合为s的方案数,然而并不会转移-- 看了hzwer的blog,发现要倒着转移,然后答案就是f[1][0] 妙啊 #include<iostream> # ...
 - bzoj1076: [SCOI2008]奖励关(期望dp+状压dp)
		
1076: [SCOI2008]奖励关 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2989 Solved: 1557[Submit][Statu ...
 - 【题解】 bzoj1076: [SCOI2008]奖励关 (装压+期望dp)
		
题面戳我 Solution 并不会做,看了下题解大概了解了.期望这个东西好难搞啊qwq 我们定义\(dp[i][j]\)表示第\(i\)步,拿到宝物前的状态为\(j\). 正着来会有很多不合法的情况, ...
 - [SCOI2008]奖励关_状压动归_数学期望
		
Code: #include<cstdio> #include<algorithm> using namespace std; const int maxn = 20; dou ...
 
随机推荐
- EOF与子过程返回
			
在2000及其以上系统,P处理语句GOTO新增了:EOF系统标签,意思是移动到当前P处理文件的结尾,EOF==END OF FILE的缩写,意为文件结尾,主要表现形式为:GOTO :EOFOR ...
 - C#连接sqlserver windows 和 sqlserver 身份验证的两种连接字符串
			
//sql server 身份验证 连接字符串 private string ConnstrSqlServer = "server=服务器名称;uid=登录名称;pwd=登录密码;datab ...
 - input  提交属性 hidden属性
			
name名字最好和你后台属性的成员变量对应,否则在参数传递的时候接收不到出现空指针异常.一般表单提交后input会以name的值=value的值的形式传给后台.如:<input type=&qu ...
 - DELL服务器iDRAC相关设置
			
iDRAC又称为Integrated Dell Remote Access Controller,也就是集成戴尔远程控制卡 iDRAC卡相当于是附加在服务器上的一台小电脑,通过与服务器主板上的管理芯片 ...
 - 通过python构建集中式的病毒扫描机制
			
Clam AntiVirus(Clam AV)是一个免费而且开放源码的防毒软件,软件与病毒库的更新由开源社区免费发布,目前ClamdAV主要为Linux.Uinux系统提供病毒扫描查杀pyClamad ...
 - python环境准备以及easy_install和pip的安装
			
python3的安装: yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline- ...
 - Becoming inspired (2) - ASC 2017 March 25
			
Becoming inspired - part 2 @ Advanced Studio Classroom Vol: 2017 MARCH 25 7.Who was I like as a chil ...
 - Mysql count+if 函数结合使用
			
Mysql count+if 函数结合使用 果林椰子 关注 2017.05.18 13:48* 字数 508 阅读 148评论 0喜欢 1 涉及函数 count函数 mysql中count函数用于统计 ...
 - hibernate中多对多的注解配置
			
hibernate多对多的注解配置中的自动生成中间表的配置: @Entity@Table(name="test_student")public class Students { @ ...
 - Lock()与RLock()锁
			
资源总是有限的,程序运行如果对同一个对象进行操作,则有可能造成资源的争用,甚至导致死锁 也可能导致读写混乱 锁提供如下方法: 1.Lock.acquire([blocking]) 2.Lock.rel ...