解题报告链接:

http://www.cnblogs.com/kuangbin/archive/2012/10/03/2711108.html

先推公式,设计状态,令DP[i]表示在房间i退出要走步数的期望值,然后推导出关系式,亮点来了,不会搜索···

so,等我学会了搜索后明天再写····

哈哈,已经学会了,自己设计的,和解题报告的不太一样,一个DFS解决···

看代码吧···我不知道怎么说····

贴代码:

 //#define debug
#include <cstdio>
#include <vector>
#include <cmath>
#define N 10005
#define eps 1e-10
using namespace std;
vector<int> ve[N];
struct node
{
double ki,wal;
} p[N];
struct para
{
double a,b,c;
};
int n;
bool vis[N];
para dfs(int x)
{
vis[x] = ;
bool flag = true;
para t,t1,t2;
//t1用来求sum(j),其中j为x的子节点
t1.a = ;
t1.b =;
t1.c = ;
for(int i=; i<ve[x].size(); ++i)
{
if(!vis[ve[x][i]])
{
flag =false;
t2 = dfs(ve[x][i]);
t1.a += t2.a;
t1.b += t2.b;
t1.c += t2.c;
}
}
// 对于非叶子节点:j为i的子节点
// Ai = (ki+(1-ki-ei)/m*∑Aj) / (1 - (1-ki-ei)/m*∑Bj);
// Bi = (1-ki-ei)/m / (1 - (1-ki-ei)/m*∑Bj);
// Ci = ( (1-ki-ei)+(1-ki-ei)/m*∑Cj ) / (1 - (1-ki-ei)/m*∑Bj);
// 对于叶子节点:
// Ai = ki;
// Bi = 1 - ki - ei;
// Ci = 1 - ki - ei;
// wal = 1-ki-exi
if(flag)//叶子节点
{
t.a = p[x].ki;
t.b = p[x].wal;
t.c = p[x].wal;
}
else//非叶子节点
{
int m = ve[x].size();
double f = - p[x].wal / m*t1.b;
t.a =(p[x].ki + p[x].wal/m*t1.a) /f ;
t.b = p[x].wal/m/f ;
t.c = (p[x].wal + p[x].wal/m*t1.c) / f;
}
return t;
}
int main()
{
#ifdef debug
freopen("in.c","r",stdin);
#endif
int t;
scanf("%d",&t);
for(int d =; d<=t ; ++d)
{
for(int i=; i<=n; ++i) ve[i].clear();
scanf("%d",&n);
for(int i=; i<n; ++i)
{
int u,v;
scanf("%d%d",&u,&v);
ve[u].push_back(v);
ve[v].push_back(u);
}
for(int i=; i<=n; ++i)
{
int k,e;
scanf("%d%d",&k,&e);
p[i].ki = (double)k/100.0;
p[i].wal = - p[i].ki - (double)e/100.0;
}
memset(vis,,sizeof(vis));
para ans = dfs();
printf("Case %d: ",d);
if(fabs(ans.a-) < eps)
printf("impossible\n");
else
printf("%.6f\n",ans.c/(-ans.a));
}
return ;
}

HDU 4035 Maze 概率DP 搜索的更多相关文章

  1. HDU 4035 Maze 概率dp,树形dp 难度:2

    http://acm.hdu.edu.cn/showproblem.php?pid=4035 求步数期望,设E[i]为在编号为i的节点时还需要走的步数,father为dfs树中该节点的父节点,son为 ...

  2. hdu 4035 Maze 概率DP

        题意:    有n个房间,由n-1条隧道连通起来,实际上就形成了一棵树,    从结点1出发,开始走,在每个结点i都有3种可能:        1.被杀死,回到结点1处(概率为ki)      ...

  3. poj 2096 Collecting Bugs && ZOJ 3329 One Person Game && hdu 4035 Maze——期望DP

    poj 2096 题目:http://poj.org/problem?id=2096 f[ i ][ j ] 表示收集了 i 个 n 的那个. j 个 s 的那个的期望步数. #include< ...

  4. HDU.4035.Maze(期望DP)

    题目链接 (直接)设\(F(i)\)为在\(i\)点走出迷宫的期望步数.答案就是\(F(1)\). 令\(p_i=1-k_i-e_i\),表示\(i\)点沿着边走的概率:\(d_i=dgr[i]\), ...

  5. HDU - 4035 循环型概率DP

    题解待会在上 #include<iostream> #include<algorithm> #include<cstdio> #include<cstring ...

  6. HDU 4035Maze(概率DP)

    HDU 4035   Maze 体会到了状态转移,化简方程的重要性 题解转自http://blog.csdn.net/morgan_xww/article/details/6776947 /** dp ...

  7. HDU4035 Maze (概率DP)

    转:https://www.cnblogs.com/kuangbin/archive/2012/10/03/2711108.html 题意: 有n个房间,由n-1条隧道连通起来,实际上就形成了一棵树, ...

  8. HDU 3853LOOPS(简单概率DP)

    HDU 3853    LOOPS 题目大意是说人现在在1,1,需要走到N,N,每次有p1的可能在元位置不变,p2的可能走到右边一格,有p3的可能走到下面一格,问从起点走到终点的期望值 这是弱菜做的第 ...

  9. HDU - 1099 - Lottery - 概率dp

    http://acm.hdu.edu.cn/showproblem.php?pid=1099 最最简单的概率dp,完全是等概率转移. 设dp[i]为已有i张票,还需要抽几次才能集齐的期望. 那么dp[ ...

随机推荐

  1. Python - Cookie绕过验证码登录

    前言 有些登录的接口会有验证码:短信验证码,图形验证码等,这种登录的话验证码参数可以从后台获取的(或者查数据库最直接). 获取不到也没关系,可以通过添加cookie的方式绕过验证码. 另一篇博文  P ...

  2. Git工作区、暂存区和版本库

    基本概念 我们先来理解下Git 工作区.暂存区和版本库概念 工作区:就是你在电脑里能看到的目录. 暂存区:英文叫stage, 或index.一般存放在 ".git目录下" 下的in ...

  3. 测试工作中经常用到的一丢Linux命令

    自己平时测试工作中经常要在Linux下搭建测试环境,有涉及到启动/终止服务器,修改tomcat配置文件,偶尔碰到端口被占用... 这时就不得不需要一些基本的Linux命令来处理遇到的这些问题 1.cd ...

  4. C#退出模式

    1.this.Close();   只是关闭当前窗口,若不是主窗体的话,是无法退出程序的,另外若有托管线程(非主线程),也无法干净地退出: 2.Application.Exit();  强制所有消息中 ...

  5. English trip -- VC(情景课)9 A Get ready

    She is doing homwork He is doing laundry He is drying the dishes She is making lunch She is making t ...

  6. linux 查找

    linux下的查找命令有很多,常用的有which.whereis.locate.find.平时在网上搜索一些教程的时候,经常会有让使用这四条命令中的一条去查找一些东西,但是经常这次说用which,下次 ...

  7. 『PyTorch』第九弹_前馈网络简化写法

    『PyTorch』第四弹_通过LeNet初识pytorch神经网络_上 『PyTorch』第四弹_通过LeNet初识pytorch神经网络_下 在前面的例子中,基本上都是将每一层的输出直接作为下一层的 ...

  8. hdu2059 dpdpdp玄学5555~~

    龟兔赛跑 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  9. 使用CLOB抛出数字或值错误异常

    今天在调试某个问题的时候,由于使用了很多循环,我需要都打印出来,试图使用clob整体处理之后再打印. 最后抛出此异常:数字或值错误. 网友解释如下: $ oerr ora 650206502, 000 ...

  10. nginx支持返回相对路径

    一.问题:http://192.168.72.4/bm-crm/  局域网可以访问[实际指向了192.168.80.1:8081/brm-crm] http://59.41.111.24:8280/b ...