BZOJ 3566 概率充电器(树形概率DP)
题面
分析
定义f(i)f(i)f(i)为iii点不被点亮的概率,p(i)p(i)p(i)为iii自己被点亮的概率,p(i,j)p(i,j)p(i,j)表示i−ji-ji−j
这条边联通的概率,有f(i)=(1−p(i))∗∏i−j( 1−p(i,j)∗(1−f(j)) )\large f(i)=(1-p(i))*\prod_{i-j}(\ \ 1-p(i,j)*(1-f(j))\ \ )f(i)=(1−p(i))∗i−j∏( 1−p(i,j)∗(1−f(j)) )
可以看出,对于一个点iii,所有于它相连的点对它的影响是独立的,那么我们首先以111为根,只考虑儿子的影响做一次树形DPDPDP。然后再进行第二次DPDPDP,只考虑父亲的影响,具体做法只需要将父亲的f(fa)f(fa)f(fa)除以iii带来的影响就得到fafafa对iii的影响。见代码
CODE
#include <bits/stdc++.h>
using namespace std;
const int MAXN = 500005;
int n, fir[MAXN], cnt;
double p[MAXN];
struct edge {
int to, nxt;
double p;
}e[MAXN<<1];
inline void add(int u, int v, double wt) {
e[++cnt] = (edge){v, fir[u], wt}; fir[u] = cnt;
e[++cnt] = (edge){u, fir[v], wt}; fir[v] = cnt;
}
double dp[MAXN];
inline void dfs1(int u, int ff) {
dp[u] = 1-p[u];
for(int i = fir[u], v; i; i = e[i].nxt)
if((v=e[i].to) != ff) dfs1(v, u), dp[u] *= 1-(1-dp[v])*e[i].p;
}
inline void dfs2(int u, int ff) {
for(int i = fir[u], v; i; i = e[i].nxt) {
if((v=e[i].to) != ff) {
double tmp = 1 - (dp[u] ? dp[u]/(1-(1-dp[v])*e[i].p) : 0); //为了不除0
dp[v] *= 1 - tmp*e[i].p;
dfs2(v, u);
}
}
}
int main () {
scanf("%d", &n);
for(int i = 1, x, y, z; i < n; ++i)
scanf("%d%d%d", &x, &y, &z), add(x, y, (double)z/100);
for(int i = 1, x; i <= n; ++i)
scanf("%d", &x), p[i] = (double)x/100;
dfs1(1, 0);
dfs2(1, 0);
double ans = 0;
for(int i = 1; i <= n; ++i)
ans += 1-dp[i];
printf("%.6f\n", ans);
}
关于在第二次dfsdfsdfs时的除法可能会除以零,是这样考虑的
- 若分母出现000,则说明dp[u]dp[u]dp[u]也一定是000,因为dp[u]dp[u]dp[u]在第一次dfsdfsdfs时本来就乘上了分母。那么此时tmp=1tmp=1tmp=1,也就是代表父亲一定会被点亮。
- 所以就判断一下dp[u]dp[u]dp[u]是否为000,再做除法就行了。
EOF\Large EOFEOF
BZOJ 3566 概率充电器(树形概率DP)的更多相关文章
- BZOJ3566: [SHOI2014]概率充电器 树形+概率dp
3566: [SHOI2014]概率充电器 Time Limit: 40 Sec Memory Limit: 256 MBSubmit: 1888 Solved: 857[Submit][Stat ...
- 【bzoj3566】[SHOI2014]概率充电器 树形概率dp
题目描述 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器:“采用全新纳米级加工技术,实现元件与导线能否通电完全由真随机数决定!SHOI 概率充电器,您生活不可或缺的 ...
- BZOJ_3566_[SHOI2014]概率充电器_概率+树形DP
BZOJ_3566_[SHOI2014]概率充电器_概率+树形DP Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器: “采用全新纳米级加工技 ...
- BZOJ 3566: [SHOI2014]概率充电器 [树形DP 概率]
3566: [SHOI2014]概率充电器 题意:一棵树,每个点\(q[i]\)的概率直接充电,每条边\(p[i]\)的概率导电,电可以沿边传递使其他点间接充电.求进入充电状态的点期望个数 糖教题解传 ...
- 【BZOJ 3566】 3566: [SHOI2014]概率充电器 (概率树形DP)
3566: [SHOI2014]概率充电器 Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器:“采用全新纳米级加工技术,实现元件与导线能否通电 ...
- BZOJ 3566: [SHOI2014]概率充电器( 树形dp )
通过一次dfs求出dp(x)表示节点x考虑了x和x的子树都没成功充电的概率, dp(x) = (1-p[x])π(1 - (1-dp[son])*P(edge(x, son)).然后再dfs一次考虑节 ...
- BZOJ3566 [SHOI2014]概率充电器 (树形DP&概率DP)
3566: [SHOI2014]概率充电器 Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器:“采用全新纳米级加工技术,实现元件与导线能否通电 ...
- luogu P4284 [SHOI2014]概率充电器 期望 概率 树形dp
LINK:概率充电器 大概是一个比较水的题目 不过有一些坑点. 根据期望的线性性 可以直接计算每个元件的期望 累和即为答案. 考虑统计每一个元件的概率的话 那么对其有贡献就是儿子 父亲 以及自己. 自 ...
- BZOJ3566:[SHOI2014]概率充电器(树形DP,概率期望)
Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器: “采用全新纳米级加工技术,实现元件与导线能否通电完全由真随机数决定!SHOI 概率充电器, ...
随机推荐
- Redis 常用命令学四:集合类型命令
1.增加和删除命令 127.0.0.1:6379> SADD st a (integer) 1 127.0.0.1:6379> SADD st r f g (integer) 3 127. ...
- Java中 final和static解析
一.final 根据程序上下文环境,Java关键字final有"这是无法改变的"或者"终态的"含义,它可以修饰非抽象类.非抽象类成员方法和变量.你可能出于两种理 ...
- SAS学习笔记29 logistic回归
变量筛选 当对多个自变量建立logistic回归模型时,并不是每一个自变量对模型都有贡献.通常我们希望所建立的模型将具有统计学意义的自变量都包含在内,而将没有统计学意义的自变量排除在外,即进行变量筛选 ...
- nacos搭建
1.下载执行包 直接官网 https://nacos.io/zh-cn/docs/quick-start.html 2. 建表 3. 启动 http://10.0.0.113:8848/nacos/i ...
- Linux发布java jar包
打包参考https://www.cnblogs.com/Rexcnblog/p/11357146.html 刚打包出来新鲜的jar 然后开始一顿猛如虎的操作了,把打包的jar和对用的sh文件拷贝到li ...
- [Es6]原生Promise的使用方法
参考:https://www.cnblogs.com/imwtr/p/5916793.html 1.new Promise(func) 通过实例化构造函数成一个promise对象,构造函数中有个函数参 ...
- axios全局配置及拦截器
axios使用说明文档 axios 全局配置: //axios-init.js import axios from 'axios': let loadingInstance; //创建Loading ...
- 再谈.NET委托(delegate、Func<>)
为了演示委托,我们先来定义一个方法:public static bool IsTen(int i){ return i == 10 ? true : false;} 如果要用自定义委托,则需要声 ...
- JS基础_this
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- springboot2.0(二)
三. Web开发 3.1.静态资源访问 在我们开发Web应用的时候,需要引用大量的js.css.图片等静态资源. 默认配置 Spring Boot默认提供静态资源目录位置需置于classpath下,目 ...