BZOJ3566 : [SHOI2014]概率充电器
选个根把无根树转化成有根树,
设f[i]表示i不通电的概率
则

答案为对于枚举树根root进行DP后1-f[root]的和
直接算是O(n^2)的,但是n有500000,所以不能过。

对于这样一棵以1为根的树,求出它的欧拉遍历序为
1->2->5->2->6->2->1->3->7->3->8->3->1->4->1
可以发现,按照这个序列,每次从上一个转移到下一个时只会在树上移动一步,
父子关系发生变化的也就只有这两个节点,
f[]值会发生变化的也就只有这两个节点。
设之前树根为r,现在准备转移到x上
在r中消去x对它的贡献
在x中加入r对它的贡献
由于是乘法,所以加入贡献只需要

但是消去贡献就不能简单的除法了,因为可能有0
所以需要在每个点多维护
c0[i]表示i的孩子里有几个对它的贡献为0
f2[i]表示i的孩子里不是0的对它贡献的积
对于转移,有两种情况:
1.r是x的父亲:
-消去r对它父亲的贡献
-消去x对它父亲的贡献

-加入r对它父亲的贡献

-加入x对它父亲的贡献
2.x是r的父亲:
-消去r对它父亲的贡献

-加入r对它父亲的贡献
-消去x对它父亲的贡献

-加入x对它父亲的贡献
总时间复杂度$O(n)$
#include<cstdio>
#define N 500010
inline void read(int&a){char c;while(!(((c=getchar())>='0')&&(c<='9')));a=c-'0';while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';}
int n,i,x,y,z,g[N],ed,v[N<<1],nxt[N<<1],a[N<<1],eu,root,fa[N],c0[N];
double w[N<<1],q[N],f[N],ans,wf[N],f2[N],eps=1e-8;
bool vis[N];
inline bool is0(double x){return x<eps;}
inline void add(int x,int y,double z){v[++ed]=y;w[ed]=z;nxt[ed]=g[x];g[x]=ed;}
void dfs(int x,int pre){
a[++eu]=x;f[x]=1-q[x];f2[x]=1;
for(int i=g[x];i;i=nxt[i])if(v[i]!=pre){
dfs(v[i],x),fa[v[i]]=x,wf[v[i]]=w[i],a[++eu]=x;
double tmp=1-w[i]+w[i]*f[v[i]];
f[x]*=tmp;
if(is0(tmp))c0[x]++;else f2[x]*=tmp;
}
}
inline void delson(int x){
double tmp=1-wf[x]+wf[x]*f[x];
if(is0(tmp))c0[fa[x]]--;else f2[fa[x]]/=tmp;
}
inline void addson(int x){
double tmp=1-wf[x]+wf[x]*f[x];
if(is0(tmp))c0[fa[x]]++;else f2[fa[x]]*=tmp;
}
inline void down(int r,int x){
delson(r);
delson(x);
f[r]=c0[r]?0:(1-q[r])*f2[r]*(1-wf[r]+wf[r]*f[fa[r]]);
addson(r);
f[x]*=1-wf[x]+wf[x]*f[r];
addson(x);
}
inline void up(int r,int x){
delson(r);
f[r]=c0[r]?0:(1-q[r])*f2[r];
addson(r);
delson(x);
f[x]*=1-wf[r]+wf[r]*f[r];
addson(x);
}
int main(){
read(n);
f[0]=1;
for(i=1;i<n;i++)read(x),read(y),read(z),add(x,y,z/100.0),add(y,x,z/100.0);
for(i=1;i<=n;i++)read(z),q[i]=z/100.0;
dfs(1,0);
ans=1-f[root=1];vis[1]=1;
for(i=2;i<=eu;i++){
if(fa[root]==a[i])up(root,a[i]);else down(root,a[i]);
if(!vis[root=a[i]])vis[root]=1,ans+=1-f[root];
}
printf("%.6f",ans);
return 0;
}
BZOJ3566 : [SHOI2014]概率充电器的更多相关文章
- BZOJ3566 SHOI2014 概率充电器 【概率DP】
BZOJ3566 SHOI2014 概率充电器 Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器: “采用全新纳米级加工技术,实现元件与导线能 ...
- BZOJ3566: [SHOI2014]概率充电器 树形+概率dp
3566: [SHOI2014]概率充电器 Time Limit: 40 Sec Memory Limit: 256 MBSubmit: 1888 Solved: 857[Submit][Stat ...
- BZOJ3566 [SHOI2014]概率充电器 (树形DP&概率DP)
3566: [SHOI2014]概率充电器 Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器:“采用全新纳米级加工技术,实现元件与导线能否通电 ...
- BZOJ3566:[SHOI2014]概率充电器(树形DP,概率期望)
Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器: “采用全新纳米级加工技术,实现元件与导线能否通电完全由真随机数决定!SHOI 概率充电器, ...
- BZOJ3566 SHOI2014概率充电器(动态规划+概率期望)
设f[i]为i在子树内不与充电点连通的概率.则f[i]=(1-pi)·∏(1-qk+qk·f[k]). 然后从父亲更新答案.则f[i]=f[i]·(1-qfa+qfa*f[fa]/(1-qfa+qfa ...
- [BZOJ3566][SHOI2014]概率充电器(概率DP)
题意:树上每个点有概率有电,每条边有概率导电,求每个点能被通到电的概率. 较为套路但不好想的概率DP. 树形DP肯定先只考虑子树,自然的想法是f[i]表示i在只考虑i子树时,能有电的概率,但发现无法转 ...
- 2018.08.31 bzoj3566: [SHOI2014]概率充电器(概率dp+容斥原理)
传送门 概率dp好题啊. 用f[i]" role="presentation" style="position: relative;">f[i] ...
- [BZOJ3566][SHOI2014]概率充电器 换根树形DP
链接 题意:n个充电元件形成一棵树,每个点和每条边都有各自的充电概率,元件可以自身充电或者通过其他点和边间接充电,求充电状态元件的期望个数 题解 设1为根节点 设 \(f[x]\) 表示 \(x\) ...
- 【BZOJ3566】[SHOI2014]概率充电器 期望+树形DP
[BZOJ3566][SHOI2014]概率充电器 Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器:“采用全新纳米级加工技术,实现元件与导线 ...
随机推荐
- ios框架
iPhone OS(现在叫iOS)是iPhone, iPod touch 和 iPad 设备的操作系统. 1,Core OS: 是用FreeBSD和Mach所改写的Darwin, 是开源 ...
- 常用iOS的第三方框架
图像:1.图片浏览控件MWPhotoBrowser 实现了一个照片浏览器类似 iOS 自带的相册应用,可显示来自手机的图片或者是网络图片,可自动从网络下载图片并进行缓存.可对图片进行缩放等 ...
- 与你相遇好幸运,MongoDB小技巧
保存为bat方便: "C://Program Files//MongoDB//Server//3.2//bin//mongod.exe" --dbpath=D://corp//db ...
- Bitmap在Java中的实现和应用
>>40亿数据排序问题 给定一个最多包含40亿个随机排列的32位整数的顺序文件,找出一个不在文件中的32位整数(在文件中至少缺失这样一个数——为什么?).在具有足够内存的情况下,如何解决该 ...
- sprintf_s的使用
int sprintf_s(char *restrict buffer, rsize_t bufsz, const char *restrict format, ...); ...
- Linux命令中特殊符号
转自:http://blog.chinaunix.net/uid-16946891-id-5088144.html 在shell中常用的特殊符号罗列如下:# ; ;; . , / \ 'strin ...
- GoLang文件增删遍历基本操作
先学一学GO语言实用的一面. package main import ( "path/filepath" "flag" "os" " ...
- less2
less2 @base-color: #000; @fore-color: darken(@base-color, 50%); @back-color: lighten(@base-color, 50 ...
- 关于ICE
转自:http://wenda.chinabaike.com/b/38322/2013/1103/614756.html 一.ICE产生的背景 基于信令协议的多媒体传输是一个两段式传输.首先,通过信令 ...
- C语言中main函数的参数
转自:http://blog.csdn.net/cnctloveyu/article/details/3905720 我们经常用的main函数都是不带参数的.因此main 后的括号都是空括号.实际上, ...