【xsy1596】旅行 期望+状压DP
题目大意:有$m$个人要从城市$1$开始,依次游览城市$1$到$n$。
每一天,每一个游客有$p_i$的概率去下一个城市,和$1-p_i$的概率结束游览。
当游客到达城市$j$,他会得到$(1+\frac{C_j}{C_{j-1}})H_{i,j}$的收益,其中$C_i$表示到访第$i$个城市的人数。
问所有人的期望收益。
数据范围:$n,m≤16$
我们考虑状压$DP$
设$f[i][S]$表示到达城市i的人群为$S$的概率。
设$ans[i][S]$表示到达城市i的人群为$S$时,所有人在前$i$座城市的收益和。
不难推出:
$f[i][S]=\sum\limits_{S∈P} f[i-1][P]\times chg(P,S)$
$ans[i][S]=\sum\limits_{S∈P} \big(ans[i-1][P]+f[i-1][P]\times sum[i][S]\times (1+\frac{|S|}{|P|})\big)\times chg(P,S)$
其中,$chg(P,S)$表示前一次游览的人群为$P$,下一次剩下$S$的概率。简单乘一下就行了。
这么转移的复杂度是$O(n\times 3^m)$的,然而他T了。。。。
#include<bits/stdc++.h>
#define M 16
#define get orzmyh
using namespace std; int m,n,all=; double p[M+]={},h[M+][M+]={},mulp[<<M]={},fmulp[<<M]={};
double f[M+][<<M]={},ans[M+][<<M]={},mo[<<M]={},sum[M+][<<M]={}; double Get(int P,int S){
return mulp[P&S]*fmulp[P^S];
}
double Sum(int day,int S){
double res=;
for(int i=;i<m;i++) if((<<i)&S){
res+=h[i][day];
}
return res;
} int main(){
scanf("%d%d",&m,&n); all=(<<m);
for(int i=;i<all;i++) mo[i]=mo[i>>]+(i&);
for(int i=;i<m;i++) scanf("%lf",p+i); for(int i=;i<all;i++){
double mul1=,mul2=;
for(int j=;j<m;j++)
if(i&(<<j)){
mul1=mul1*p[j];
mul2=mul2*(-p[j]);
}
mulp[i]=mul1;
fmulp[i]=mul2;
} for(int i=;i<m;i++)
for(int j=;j<=n;j++)
scanf("%lf",&h[i][j]); for(int i=;i<=n;i++){
for(int S=;S<all;S++)
sum[i][S]=Sum(i,S);
}
f[][all-]=; ans[][all-]=sum[][all-];
for(int i=;i<=n;i++){
for(int P=;P<all;P++)
for(int S=P;~S;S=P&(S-)){
double val=Get(S,P);
f[i][S]+=f[i-][P]*val;
ans[i][S]+=(ans[i-][P]+(mo[P]?sum[i][S]*(+mo[S]/mo[P])*f[i-][P]:))*val;
if(S==) break;
}
}
double Ans=;
for(int S=;S<all;S++)
Ans+=ans[n][S];
printf("%.10lf\n",Ans);
}
于是我后来写了一个$O(nm\times 2^m)$的,代码如下:
#include<bits/stdc++.h>
#define M 17
using namespace std; double f[M][M]={},h[M][M]={},p[M]={};
int n,m; int main(){
scanf("%d%d",&m,&n);
for(int i=;i<=m;i++) scanf("%lf",p+i);
for(int i=;i<=m;i++){
f[i][]=;
for(int j=;j<=n;j++)
f[i][j]=f[i][j-]*p[i];
}
double ans=;
for(int i=;i<=m;i++){
for(int j=;j<=n;j++){
scanf("%lf",&h[i][j]);
ans+=f[i][j]*h[i][j];
}
}
for(int i=;i<n;i++){
for(int s=;s<(<<m);s++){
double ps=,sum=,pn=; int cnt=;
for(int j=;j<=m;j++) if(s&(<<(j-))){
ps*=f[j][i];
cnt++;
pn+=p[j];
}else ps*=-f[j][i]; for(int j=;j<=m;j++) if(s&(<<(j-)))
sum+=p[j]*h[j][i+]*(pn-p[j]+);
ans+=ps*sum/cnt;
}
}
printf("%.10lf\n",ans);
}
【xsy1596】旅行 期望+状压DP的更多相关文章
- 2018.09.23 bzoj1076: [SCOI2008]奖励关(期望+状压dp)
传送门 一道神奇的期望状压dp. 用f[i][j]f[i][j]f[i][j]表示目前在第i轮已选取物品状态为j,从现在到第k轮能得到的最大贡献. 如果我们从前向后推有可能会遇到不合法的情况. 所以我 ...
- “景驰科技杯”2018年华南理工大学程序设计竞赛 A. 欧洲爆破(思维+期望+状压DP)
题目链接:https://www.nowcoder.com/acm/contest/94/A 题意:在一个二维平面上有 n 个炸弹,每个炸弹有一个坐标和爆炸半径,引爆它之后在其半径范围内的炸弹也会爆炸 ...
- BZOJ3925: [Zjoi2015]地震后的幻想乡【概率期望+状压DP】
Description 傲娇少女幽香是一个很萌很萌的妹子,而且她非常非常地有爱心,很喜欢为幻想乡的人们做一些自己力所能及的事情来帮助他们. 这不,幻想乡突然发生了地震,所有的道路都崩塌了.现在的首要任 ...
- BZOJ5006 THUWC2017随机二分图(概率期望+状压dp)
下称0类为单边,1类为互生边,2类为互斥边.对于一种匹配方案,考虑其出现的概率*2n后对答案的贡献,初始为1,如果有互斥边显然变为0,否则每有一对互生边其贡献*2.于是有一个显然的dp,即设f[S1] ...
- 状压DP小拼盘
有的DP题,某一部分的状态只有两种,选或不选. 开数组记录,代价太大,转移不方便. 状态压缩意为,用 “0/1“ 表示 “选/不选“ . 把状态表示为二进制整数. There are 10 kinds ...
- 【BZOJ】1076 [SCOI2008]奖励关 期望DP+状压DP
[题意]n种宝物,k关游戏,每关游戏给出一种宝物,可捡可不捡.每种宝物有一个价值(有负数).每个宝物有前提宝物列表,必须在前面的关卡取得列表宝物才能捡起这个宝物,求期望收益.k<=100,n&l ...
- BZOJ1076 [SCOI2008]奖励关 【状压dp + 数学期望】
1076: [SCOI2008]奖励关 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 3074 Solved: 1599 [Submit][Sta ...
- Problem Arrangement ZOJ - 3777(状压dp + 期望)
ZOJ - 3777 就是一个入门状压dp期望 dp[i][j] 当前状态为i,分数为j时的情况数然后看代码 有注释 #include <iostream> #include <cs ...
- [思路题][LOJ2290][THUWC2017]随机二分图:状压DP+期望DP
分析 考虑状压DP,令\(f[sta]\)表示已匹配状态是\(sta\)(\(0\)代表已匹配)时完美匹配的期望数量,显然\(f[0]=1\). 一条边出现了不代表它一定在完美匹配内,这也导致很难去直 ...
随机推荐
- windows 远程连接“发生身份验证错误 要求的函数不受支持”
Windows Registry Editor Version 5.00 [HKEY_LOCAL_MACHINE\Software\Microsoft\Windows\CurrentVersion\P ...
- gdbserver
这里写下gdbserver的用法: 两台机子,宿主机A和目标机B. step1: 我们在B上安装gdbserver,在A上编译可执行程序a.out,把a.out拷贝到B上面去. step2: 在A上打 ...
- mysql学习笔记--数据库操作
一.显示数据库 show databases; 二.创建数据库 create database [if not exists] 数据库名 [字符编码] 注意: a. 如果已经存在数据库再创建会报错 b ...
- 在VMware的虚拟机中克隆CentOS,在重启网卡的时候报错解决办法
克隆虚拟机配置 1.修改:vi /etc/hosts 2.修改:vi /etc/sysconfig/network 3.重启生效:reboot或者init 6 如不重启可以输入:hostname 新 ...
- FortiGate日常检查
1.1)CPU利用率:由于防火墙有芯片,正常的流量都走芯片转发,不走cpu,只有开了utm相关的应用层防护功能和DDOS之类的,才会走cpu,所以一般cpu都不会占用太多,甚至很多时间都是0%, 如果 ...
- [leetcode]23. Merge k Sorted Lists归并k个有序链表
Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexity. I ...
- java_18 Collection接口
1.Collection接口 Collection 层次结构 中的根接口.Collection 表示一组对象,这些对象也称为 collection 的元素.一些 collection 允许有重复的元素 ...
- 源发行版 1.8 需要目标发行版 1.8以及usage of api documented as @since 1.8+
Maven项目每个Module都有单独的pom.xml,如果不在pom.xml中进行配置,则默认将Module的Language Level设置为5.所以要在pom.xml文件中添加插件进行配置. & ...
- android 设置LOGO和app名称
mipmap和drawable目录都可以存放图片,一般情况下,将LOGO文件存放在mipmap目录,普通图片放到drawable目录. 一.在mipmap目录添加LOGO图片 在mipmap目录右键- ...
- SpringMVC学习笔记:拦截器和过滤器
首先说明一下二者的区别: 1. 拦截器基于java的反射机制,而过滤器是基于函数回调 2. 拦截器不依赖于servlet容器,过滤器依赖servlet容器 3. 拦截器只能对action请求起作用,而 ...