HDU 4035Maze(树状+概率dp,绝对经典)
题意:
给你n个节点的树,从1节点开始走,到每个节点都有三种情况,被杀死回到1节点,找到隐藏的出口出去,沿着当前节点相邻的边走到下一个节点,给出每个节点三种情况发生的概率分别为ki,ei,1-ki-ei,求找到出口时已经过的边数的期望。
分析:
用树状dp考虑问题。当节点是叶子节点时它只是向父节点走,非叶子节点可以向父亲节点和所有孩子节点走。
Ei表示到i节点经过边数的期望
则叶子节点:Ei=ki*E1+(1-ki-ei)*(E[par[i]]+1);//par[i]表示i的父亲节点
非叶子节点:Ei=ki*E1+(1-ki-ei)*(E[par[i]]/m+Σ(E[son[i]])/m+1)//m表示与i节点相连的边数,son[i]表示i节点孩子
接下来就是处理环了
令 Ei=ai*E1+bi*E[par[i]]+ci;//关键
叶子节点:ai=ki,bi=1-ki-ei,ci=1-ki-ei
非叶子节点:设j是i的孩子Σ(E[son[i]]=Σ(E[j])=Σai*E1+Σbi*Ei+Σci代入得
令 tmp=(1-ki-ei)*Σbi/m;
ai=(ki+(1-ki-ei)*Σai/m)/(1-tmp)
bi=(1-ki-ei)/(1-tmp)/m;
ci=((1-ki-ei)*Σci/m+1-ki-ei)/(1-tmp);
则E1=a1*E1+bi*0+ci可得答案,当tmp趋于1时无解
#include <map>
#include <set>
#include <list>
#include <cmath>
#include <queue>
#include <stack>
#include <cstdio>
#include <vector>
#include <string>
#include <cctype>
#include <complex>
#include <cassert>
#include <utility>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
using namespace std;
typedef pair<int,int> PII;
typedef long long ll;
#define lson l,m,rt<<1
#define pi acos(-1.0)
#define rson m+1,r,rt<<11
#define exp 1e-9
#define All 1,N,1
#define N 10010
#define read freopen("in.txt", "r", stdin)
const ll INFll = 0x3f3f3f3f3f3f3f3fLL;
const int INF= 0x7ffffff;
const int mod = ;
int used[N],f,n;
double e[N],k[N],a[N],b[N],c[N];
vector<int>t[N];
void dfs(int u){
if(f)return;
used[u]=;
int num=t[u].size();
a[u]=k[u];
b[u]=(-k[u]-e[u])/num;
c[u]=-k[u]-e[u];
double tmp=;
for(int i=;i<num;++i){
int v=t[u][i];
if(used[v])continue;
dfs(v);
a[u]+=(-k[u]-e[u])/num*a[v];
tmp+=(-k[u]-e[u])/num*b[v];
c[u]+=(-k[u]-e[u])/num*c[v];
}
if(fabs(-tmp)<exp){
f=;
return;
}
a[u]/=(-tmp);
b[u]/=(-tmp);
c[u]/=(-tmp);
}
int main()
{
int test,cas=;
scanf("%d",&test);
while(test--){
scanf("%d",&n);
for(int i=;i<=n;++i)
t[i].clear();
int st,ed;
for(int i=;i<n-;++i){
scanf("%d%d",&st,&ed);
t[st].push_back(ed);
t[ed].push_back(st);
}
int kk,ee;
for(int i=;i<=n;++i){
scanf("%d%d",&kk,&ee);
k[i]=kk/100.0;
e[i]=ee/100.0;
}
memset(used,,sizeof(used));
f=;
dfs();
printf("Case %d: ",++cas);
if(!f&&(1.0-a[])>exp){
printf("%lf\n",c[]/(-a[]));
}
else{
printf("impossible\n");
}
}
return ;
}
HDU 4035Maze(树状+概率dp,绝对经典)的更多相关文章
- hdu 2227(树状数组+dp)
Find the nondecreasing subsequences Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/3 ...
- hdu 4991(树状数组+DP)
Ordered Subsequence Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 4638 树状数组 区间内连续区间的个数(尽可能长)
Group Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- hdu 4777 树状数组+合数分解
Rabbit Kingdom Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...
- 【bzoj4006】[JLOI2015]管道连接 斯坦纳树+状压dp
题目描述 给出一张 $n$ 个点 $m$ 条边的无向图和 $p$ 个特殊点,每个特殊点有一个颜色.要求选出若干条边,使得颜色相同的特殊点在同一个连通块内.输出最小边权和. 输入 第一行包含三个整数 n ...
- hdu 4622 Reincarnation trie树+树状数组/dp
题意:给你一个字符串和m个询问,问你l,r这个区间内出现过多少字串. 连接:http://acm.hdu.edu.cn/showproblem.php?pid=4622 网上也有用后缀数组搞得. 思路 ...
- HDU 6348 序列计数 (树状数组 + DP)
序列计数 Time Limit: 4500/4000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total Subm ...
- 2018 CCPC网络赛 1010 hdu 6447 ( 树状数组优化dp)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6447 思路:很容易推得dp转移公式:dp[i][j] = max(dp[i][j-1],dp[i-1][j ...
- 【树状数组+dp】HDU 5542 The Battle of Chibi
http://acm.hdu.edu.cn/showproblem.php?pid=5542 [题意] 给定长为n的序列,问有多少个长为m的严格上升子序列? [思路] dp[i][j]表示以a[i]结 ...
随机推荐
- secure CRT 介绍
SecureCRT是一款支持SSH(SSH1和SSH2)的终端仿真程序,简单地说是Windows下登录UNIX或Linux服务器主机的软件. Secure[1] CRT支持SSH,同时 ...
- linux网络配置、环境变量以及JDK安装(CentOS 6.5)
由于需要搭建hadoop平台,但是苦于没有现成可用的linux服务器,只好自己下载了CentOS 6.5从头装起,安装过程中遇到了很多问题,比如网络配置.时钟同步.环境变量配置.以及各种服务的启停,还 ...
- lintcode:next permutation下一个排列
题目 下一个排列 给定一个整数数组来表示排列,找出其之后的一个排列. 样例 给出排列[1,3,2,3],其下一个排列是[1,3,3,2] 给出排列[4,3,2,1],其下一个排列是[1,2,3,4] ...
- Project Euler 76:Counting summations
题目链接 原题: It is possible to write five as a sum in exactly six different ways: 4 + 13 + 23 + 1 + 12 + ...
- mysql级联删除更新
首先,目前在产品环境可用的MySQL版本(指4.0.x和4.1.x)中,只有InnoDB引擎才允许使用外键,所以,我们的数据表必须使用InnoDB引擎. 下面,我们先创建以下测试用数据库表: CREA ...
- 让Windows蓝屏死机
ssdt 随便一个函数入口改90就蓝了 ------------------------------------------------- program Project2; uses Windows ...
- java:访问权限
访问权限四大类:权限从大->小 1.public: 公共权限 2.protected: 受保护权限 3.default: 包级别访问权限/默认权限 4.private: 私有权限 以p ...
- HDU2521反素数
只是了解下这种简单的数论定义,解释可以戳这个 http://www.cnblogs.com/Findxiaoxun/p/3460450.html ,然后按Ctrl+ F搜索 反素数 ,找到那一部 ...
- java开发之匿名内部类,接口的使用
下面的例子是Java.JDK7学习笔记上的 打算开发多人联机程序,对每个联机客户端,都会建立Client对象封装相关信息 1.Client.java public class Client { pri ...
- 【Todo】淘宝十年产品事-读书笔记
书籍位置: /Users/baidu/Documents/Data/Interview/业界/淘宝十年产品事.pdf