加油,两道了,也就还剩那么二十来道吧,慢慢做。。。。。。

题目大意:

给你一颗树,树上的每一个节点都有一定的概率p[i]能冲上电,有电的点,可以通过树上的边,一定概率地将电传递到与它相邻的点,同时对于每条边,都有一个传递电能的成功率。让你求出通电节点个数的期望。

读入:一个数n,接下来n-1行,每行三个数u,v,p,表示有一条连接节点u和v的边,导电的概率为p,最后一行共n个数,表示每个节点一开始就有电的概率。

  1. 输出:一个数E,表示期望(取6位小数)。

思路分析:

换根DP+期望DP

很清楚,最后的答案就是每一个点通电的概率相加。那么对于每一个点,我们可以求出它不通电的概率,然后再用1去减就可以了。(求不通电的概率比较简单)

有了大致的思路,我们就可以开始设计DP啦!

以1为根,我们开始做树形DP。

对于每一个点u,我们将其分两种情况讨论:

1、以u为根的子树无法使其通上电。

我们建立一个f数组,其中f[u]表示以u为根的子树,无法使u通上电的概率。

那么对于每一个u的儿子v,它不能使u通电又有两种情况:

a、它的儿子v不通电。

b、v通电,但是连接u,v的边不导电。

所以:f[u]=(1-p[u])∏v∈u's son(f[v]+(1-f[v])*(1-P[u,v]))          其中P表示u,v通电的概率

注意:因为a,b两种情况是互斥的两种情况所以f[v]和(1-f[v])*(1-P[u,v])应相加,而对于每一个v无论是哪一个v使u通电都一样,他们是独立的,所以是相乘。

2、u的父亲无法使u通上电。

这种情况,这,这,这——这TM玩个鸡儿啊!!!

万念俱灰,推出了一个看似完美的DP但最终仍是难逃被题目蹂躏的命运。

这第二种情况应该怎么处理呢?怎么处理呢?不会啊,怎么办呢?——不会那就不处理呗!!!

我们都知道,在一棵树中,有一个叫做根节点的神奇玩意儿——它是没有父亲的!

所以再不济,我们以每一个节点为根跑一遍上面的DP不就完事儿了吗!

但是我们真的需要这么做吗?——肯定不用啊!

一遍DP之后得到的大好信息,我们怎么能说扔就扔了呢?浪费可耻啊!

我们建立数组g,其中g[u]为以u为根节点,点u不被充电的概率,显然f[1]=g[1]。

那么我们考虑节点v(v为1号节点的一个儿子),再设一个x为以1为根节点的树,不算儿子v对于1号节点的影响,1号节点不被充电的概率。

那么:g[v]=f[v]*(x+(1-x)*(1-P[1,v]))

而x也很好求,因为对于1号节点的每一个儿子节点,他们对于一号节点的影响都是相对独立的,所以x=g[1]/(f[v]+(1-f[v])*(1-P[1,v]))。

所以整个g数组的转移就被我们推导出来啦!即:g[v]=f[v]*(x+(1-x)*(1-P[u,v]))   其中:x=g[u]/(f[v]+(1-f[v])*(1-P[u,v]))

代码:

var
next,head,vet:array[1..1000000]of longint;
vis:array[1..500000]of boolean;
p,f,dist,g:array[1..1000000]of double;
tot,i,n,x,y:longint;
ans,z:double;
procedure add(x,y:longint;z:real);
begin
inc(tot);
next[tot]:=head[x];
vet[tot]:=y;
head[x]:=tot;
dist[tot]:=z;
end;
procedure dfs(u:longint);
var
i,v:longint;
begin
vis[u]:=true; i:=head[u];
while i<>0 do
begin
v:=vet[i];
if not vis[v] then
begin
dfs(v);
f[u]:=f[u]*(f[v]+(1-f[v])*(1-dist[i]));
end;
i:=next[i];
end;
end;
procedure change(u:longint);
var
i,v:longint;
x:double;
begin
vis[u]:=true; i:=head[u];
while i<>0 do
begin
v:=vet[i];
if not vis[v] then
begin
x:=g[u]/(f[v]+(1-f[v])*(1-dist[i]));
g[v]:=f[v]*(x+(1-x)*(1-dist[i]));
change(v);
end;
i:=next[i];
end;
end;
begin
read(n);
for i:=1 to n-1 do
begin
read(x,y,z);
add(x,y,z/100); add(y,x,z/100);
end;
for i:=1 to n do
begin
read(p[i]);
p[i]:=p[i]/100;
f[i]:=1-p[i];
end;
dfs(1);
g[1]:=f[1];
fillchar(vis,sizeof(vis),false);
change(1);
for i:=1 to n do
ans:=ans+1-g[i]; 
writeln(ans:0:6);
end.

SHOI 2014 【概率充电器】的更多相关文章

  1. [bzoj 3566][SHOI 2014]概率充电器

    传送门 Description SHOI 概率充电器由 n-1 条导线连通了 n 个充电元件.进行充电时,每条导线是否可以导电以概率决定,每一个充电元件自身是否直接进行充电也由概率决定. 随后电能可以 ...

  2. [ SHOI 2014 ] 概率充电器

    \(\\\) \(Description\) 一个含\(N\)个元器件的树形结构充电器,第\(i\)个元器件有\(P_i\)的概率直接从外部被充电,连接\(i,j\)的边有\(P_{i,j}\)的概率 ...

  3. 解题:SHOI 2014 概率充电器

    题面 显然就是在求概率,因为期望乘的全是1....然后就推推推啊 设$fgg[i]$表示这个点父亲没给他充上电的概率,$sgg[i]$表示这个点子树(和它自己)没给他充上电的概率,然后这个点没充上电的 ...

  4. BZOJ 3566: [SHOI2014]概率充电器( 树形dp )

    通过一次dfs求出dp(x)表示节点x考虑了x和x的子树都没成功充电的概率, dp(x) = (1-p[x])π(1 - (1-dp[son])*P(edge(x, son)).然后再dfs一次考虑节 ...

  5. bzoj 3566: [SHOI2014]概率充电器

    Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品--概率充电器:"采用全新纳米级加工技术,实现元件与导线能否通电完全由真随机数决定!SHOI 概率 ...

  6. [SHOI2014]概率充电器

    Description 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品——概率充电器: “采用全新纳米级加工技术,实现元件与导线能否通电完全由真随机数决定!SHOI 概率充电器, ...

  7. Loj #2192. 「SHOI2014」概率充电器

    Loj #2192. 「SHOI2014」概率充电器 题目描述 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品--概率充电器: 「采用全新纳米级加工技术,实现元件与导线能否通电完 ...

  8. [SHOI2014]概率充电器(概率+换根dp)

    著名的电子产品品牌SHOI 刚刚发布了引领世界潮流的下一代电子产品—— 概率充电器: “采用全新纳米级加工技术,实现元件与导线能否通电完全由真随机数决 定!SHOI 概率充电器,您生活不可或缺的必需品 ...

  9. BZOJ3566: [SHOI2014]概率充电器 树形+概率dp

    3566: [SHOI2014]概率充电器 Time Limit: 40 Sec  Memory Limit: 256 MBSubmit: 1888  Solved: 857[Submit][Stat ...

  10. 洛谷 P4284 [SHOI2014]概率充电器 解题报告

    P4284 [SHOI2014]概率充电器 题目描述 著名的电子产品品牌SHOI 刚刚发布了引领世界潮流的下一代电子产品-- 概率充电器: "采用全新纳米级加工技术,实现元件与导线能否通电完 ...

随机推荐

  1. spring cloud 路由

    Spring Cloud Feign:用于微服务之间,只映射内网ip Spring Cloud Gateway:用于服务端,对外开放的接口,对外统一访问gateway映射的ip 是这样吗? 但是这样权 ...

  2. HDU - 1005 -Number Sequence(矩阵快速幂系数变式)

    A number sequence is defined as follows:  f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) + B * f(n - 2)) m ...

  3. 在centos6.5下搭建lnmp

    1.查看环境: [root@localhost /]# cat /etc/redhat-release CentOS release 6.5 (Final)   2.关掉防火墙(需要到国外地址下载软件 ...

  4. Java清空一个指定文件

    清空test.log文件所有内容 File log = new File("c:\\test\\test.log"); FileWriter fileWriter =new Fil ...

  5. oracle之三手工备份与恢复

    手工备份与恢复 2.1 手工备份和恢复的命令 1)备份和还原都使用OS命令,如linux中的cp 2)恢复用sqlplus命令:recover 2.2 备份前要对数据库进行检查: 1) 检查需要备份的 ...

  6. Salesforce Javascript(一) Promise 浅谈

    本篇参看: https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Promise https ...

  7. php第五天-正则表达式,字符串的匹配与查找函数,数组切割

    在php中有两套正则表达式,两者功能相似,一套是由PCRE,使用"preg_"为前缀命名的函数,一套是由POSIX拓展提供的,使用以"ereg_"命名的函数 0 ...

  8. 手把手教你在容器服务 TKE 上使用 LB 直通 Pod

    什么是 LB 直通 Pod ? Kubernetes 官方提供了 NodePort 类型的 Service,即给所有节点开一个相同端口用于暴露这个 Service,大多云上 LoadBalancer ...

  9. BUUCTF[归纳]sql注入相关题目

    这是我自己对于sql注入的部分ctf题型的归纳,均来自buuctf的平台环境. [0CTF 2016]piapiapia 我尝试了几种payload,发现有两种情况. 第一种:Invalid user ...

  10. Mac 系统下如何显示和隐藏文件

    苹果Mac OS X操作系统下,隐藏文件是否显示有很多种设置方法,最简单的要算在Mac终端输入命令.显示/隐藏Mac隐藏文件命令如下(注意其中的空格并且区分大小写): 第一种方式: 显示Mac隐藏文件 ...