P4284 [SHOI2014]概率充电器


今天上课讲到的题orz,第一次做这种上下搞两次dp的题。

g[i]表示i的子树(包括i)给i充电的概率。

f[i]表示i的父亲给i充电的概率。

g[]可以快速求出来。h[i]表示i对i父亲的贡献,则

\(h_i=g_i+(1-g_i)(1-w(i,fa_i))\)

\(g_i=(1-q_i)\Pi_{j=son}h_j\)

\(w(i,fa_i)\)即\(i\)与\(fa_i\)之间路径的长度。

但是f[]就不好求了= =

上面已经求出了f[y],要求f[x]。f[x]需要计算除了x的子树之外的所有点。

可以把这些点分成两部分:绿色和紫色部分

紫色部分就是f[y],但绿色呢?

回去看一眼:\(g_y=(1-q_y)\Pi_{j=son}h_j\)

所以只需要除掉\(h_x\)就星了。

\(t=\frac{g_yf_y}{h_x}\)

\(f_x=t+(1-t)(1-w(x,y))\)

注意t不是\(f_x\),t是去掉x子树后y通电的概率,可参照h的求法


上述方法可获得95分的好成绩。

因为\(t=\frac{g_yf_y}{h_x}\),如果遇到0就GG了。。。

观察一下,\(h_x=0\)的话,t实际是0(因为上面一定会通电下来??

然后写完了= =

#include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<cctype>
using namespace std;
typedef int mmp;
#define vd void
#define rg register
#define il inline
#define sta static
il int gi(){
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch))x=x*10+ch-'0',ch=getchar();
return x*f;
}
const int maxn=500001;
int id,fir[maxn],nxt[maxn<<1],dis[maxn<<1],w[maxn<<1];
int p[maxn];
il vd link(int x,int y,int z){nxt[++id]=fir[x],fir[x]=id,dis[id]=y,w[id]=z;}
double f[maxn],g[maxn],h[maxn];
il vd dp(int x,int fa=-1){
g[x]=1-p[x]*.01;
for(rg int i=fir[x];i;i=nxt[i]){
if(fa==dis[i])continue;
dp(dis[i],x);
h[dis[i]]=g[dis[i]]+(1-g[dis[i]])*(1-w[i]*.01);
g[x]*=h[dis[i]];
}
}
il vd dp2(int x,int fa=-1){
for(rg int i=fir[x];i;i=nxt[i]){
if(fa==dis[i])continue;
double t=(h[dis[i]]<1e-6)?0:g[x]*f[x]/h[dis[i]];
f[dis[i]]=t+(1-t)*(1-w[i]*.01);
dp2(dis[i],x);
}
}
mmp main(){
// freopen("4284.in","r",stdin);
// freopen("4284.out","w",stdout);
int n=gi();
for(rg int i=1;i<n;++i){
sta int a,b,p;
a=gi(),b=gi(),p=gi();
link(a,b,p),link(b,a,p);
}
for(rg int i=1;i<=n;++i)p[i]=gi();
dp(1);f[1]=1;dp2(1);
double ans=0;
for(rg int i=1;i<=n;++i)ans+=1-f[i]*g[i];
printf("%.6lf\n",ans);
// for(rg int i=1;i<=n;++i)printf("%.6lf ",f[i]);puts("");
// for(rg int i=1;i<=n;++i)printf("%.6lf ",g[i]);puts("");
// for(rg int i=1;i<=n;++i)printf("%.6lf ",h[i]);puts("");
return 0;
}

P4284 [SHOI2014]概率充电器的更多相关文章

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

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

  2. 洛谷 P4284 [SHOI2014]概率充电器 概率与期望+换根DP

    洛谷 P4284 [SHOI2014]概率充电器 概率与期望+换根DP 题目描述 著名的电子产品品牌\(SHOI\) 刚刚发布了引领世界潮流的下一代电子产品-- 概率充电器: "采用全新纳米 ...

  3. P4284 [SHOI2014]概率充电器 dp

    这个题题干说的不清楚,一开始我以为只能是旁边紧挨着的传火,导致我一开始根本不知道哪错了.后来,我想到树形dp,但是需要正反考虑,()既要考虑父亲,又要考虑儿子),互相都有影响,所以没太想出来.后来知道 ...

  4. luogu P4284 [SHOI2014]概率充电器 期望 概率 树形dp

    LINK:概率充电器 大概是一个比较水的题目 不过有一些坑点. 根据期望的线性性 可以直接计算每个元件的期望 累和即为答案. 考虑统计每一个元件的概率的话 那么对其有贡献就是儿子 父亲 以及自己. 自 ...

  5. Bzoj3566/洛谷P4284 [SHOI2014]概率充电器(概率dp)

    题面 Bzoj 洛谷 题解 首先考虑从儿子来的贡献: $$ f[u]=\prod_{v \in son[u]}f[v]+(1-f[v])\times(1-dis[i]) $$ 根据容斥原理,就是儿子直 ...

  6. 【题解】Luogu P4284 [SHOI2014]概率充电器

    原题传送门 我们知道,每个电器充电对充电电器数的贡献都是相等的1,所以若第\(i\)个电器有\(p_i\)的概率充电时 \[E=\sum_{i=1}^np_i\] 我们考虑如何求\(p_i\),根据树 ...

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

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

  8. BZOJ 3566: [SHOI2014]概率充电器 [树形DP 概率]

    3566: [SHOI2014]概率充电器 题意:一棵树,每个点\(q[i]\)的概率直接充电,每条边\(p[i]\)的概率导电,电可以沿边传递使其他点间接充电.求进入充电状态的点期望个数 糖教题解传 ...

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

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

随机推荐

  1. zabbix的日常监控-磁盘性能监控(十二)

    监控磁盘的性能 参考文章: https://wiki.enchtex.info/howto/zabbix/zabbix_iostat_monitoring https://blog.csdn.net/ ...

  2. 开源作业调度框架 - Quartz.NET - 实战使用1

    简介: 第一步:下载Quartz.NET 下载Quartz.NET只需要打开网址选择适宜的版本进行下载解压缩即可. 目前最新版本是2.3.3,压缩包为6MB,不过鉴于国内网速.我还是加一下博客园的下载 ...

  3. PHP设计模式系列 - 单例

    单例模式 通过提供自身共享实例的访问,单例设计模式用于限制特定对象只能被创建一次. 使用场景 例如数据库实例,一般都会走单例模式. 单例模式可以减少类的实例化 代码:来源InitPHP框架,先检测类有 ...

  4. 深入 Java 调试体系: 第 1 部分,初探JPDA 体系

    JPDA(Java Platform Debugger Architecture)是 Java 平台调试体系结构的缩写,通过 JPDA 提供的 API,开发人员可以方便灵活的搭建 Java 调试应用程 ...

  5. python中string格式化

    python中可以对string, int, float等数据类型进行格式化操作.下面举例来说明一些常用操作. 先贴出 python 对 String Formatting Operations 讲解 ...

  6. Python基础.md

    数据结构 列表 访问 list1 = ['java','C','C++','Python'] In [10]: list1[1] Out[10]: 'C' In [11]: list1[-1] Out ...

  7. 智能家居中的物联网网关的可信计算平台模块(TPM)设计

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/BlueCloudMatrix/article/details/24184461 摘要: 随着智能家居 ...

  8. 基于反射启动Spring容器

    基于反射启动Spring容器 package com.maple.test; import org.springframework.context.ApplicationContext; import ...

  9. 关于Golang中database/sql包的学习

    go-sql-driver 请求一个连接的函数有好几种,执行完毕处理连接的方式稍有差别,大致如下: db.Ping() 调用完毕后会马上把连接返回给连接池. db.Exec() 调用完毕后会马上把连接 ...

  10. 2251. [2010Beijing Wc]外星联络【后缀数组】

    Description 小 P 在看过电影<超时空接触>(Contact)之后被深深的打动,决心致力于寻 找外星人的事业.于是,他每天晚上都爬在屋顶上试图用自己的收音机收听外星 人发来的信 ...