hdu 4035 Maze(期待更多经典的树DP)
Maze
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Others)
Total Submission(s): 1677 Accepted Submission(s): 638
Special Judge
The maze consisted by N rooms and tunnels connecting these rooms. Each pair of rooms is connected by one and only one path. Initially, lxhgww is in room 1. Each room has a dangerous trap. When lxhgww step into a room, he has a possibility to be killed and restart
from room 1. Every room also has a hidden exit. Each time lxhgww comes to a room, he has chance to find the exit and escape from this maze.
Unfortunately, lxhgww has no idea about the structure of the whole maze. Therefore, he just chooses a tunnel randomly each time. When he is in a room, he has the same possibility to choose any tunnel connecting that room (including the tunnel he used to come
to that room).
What is the expect number of tunnels he go through before he find the exit?
At the beginning of each case is an integer N (2 ≤ N ≤ 10000), indicates the number of rooms in this case.
Then N-1 pairs of integers X, Y (1 ≤ X, Y ≤ N, X ≠ Y) are given, indicate there is a tunnel between room X and room Y.
Finally, N pairs of integers Ki and Ei (0 ≤ Ki, Ei ≤ 100, Ki + Ei ≤ 100, K1 = E1 = 0) are given, indicate the percent of the possibility of been killed and exit in the ith room.
from the maze, output “impossible”.
3 3 1 2 1 3 0 0 100 0 0 100 3 1 2 2 3 0 0 100 0 0 100 6 1 2 2 3 1 4 4 5 4 6 0 0 20 30 40 30 50 50 70 10 20 60
Case 1: 2.000000 Case 2: impossible Case 3: 2.895522
你開始在以后房间。
你每一个房间你有ki的概率被杀掉。
ei的概率逃出迷宫。假设既没被杀掉又没逃出去。你就会随机选一条能走的边走,最后问你走出这个迷宫须要走的边数的期望。
然后也能够写出状态转移方程
所以最后还是没做出来。然后就仅仅有看题解咯。
还是做题太少啊。这题被我忽略了非常重要的一点那就是这是一颗树而不是一张图。
而我的方程全然没体现它是树的特点。
- #include<algorithm>
- #include<iostream>
- #include<string.h>
- #include<stdio.h>
- #include<math.h>
- using namespace std;
- const int INF=0x3f3f3f3f;
- const int maxn=10010;
- const double eps=1e-10;//開始-6wa了。精度要高点才行。
- typedef long long ll;
- struct node
- {
- int v;
- node *next;
- } ed[maxn<<1],*head[maxn];
- int cnt,eds[maxn];
- double A[maxn],B[maxn],C[maxn],ki[maxn],ei[maxn];
- void adde(int u,int v)
- {
- ed[cnt].v=v;
- ed[cnt].next=head[u];
- head[u]=&ed[cnt++];
- }
- void dfs(int fa,int u)
- {
- double sa,sb,sc,mi;
- sa=sb=sc=0;
- for(node *p=head[u];p!=NULL;p=p->next)
- {
- if(p->v==fa)
- continue;
- dfs(u,p->v);
- sa+=A[p->v];
- sb+=B[p->v];
- sc+=C[p->v];
- }
- mi=(1-ki[u]-ei[u])/eds[u];
- A[u]=(ki[u]+mi*sa)/(1-mi*sb);
- B[u]=mi/(1-mi*sb);
- C[u]=(1+mi*sc-ki[u]-ei[u])/(1-mi*sb);
- }
- int main()
- {
- int t,cas=1,n,i,u,v;
- scanf("%d",&t);
- while(t--)
- {
- scanf("%d",&n);
- cnt=0;
- memset(head,0,sizeof head);
- memset(eds,0,sizeof eds);
- for(i=1;i<n;i++)
- {
- scanf("%d%d",&u,&v);
- eds[u]++,eds[v]++;
- adde(u,v);
- adde(v,u);
- }
- for(i=1;i<=n;i++)
- {
- scanf("%lf%lf",&ki[i],&ei[i]);
- ki[i]/=100,ei[i]/=100;
- }
- dfs(-1,1);
- printf("Case %d: ",cas++);
- if(fabs(1-A[1])<eps)
- printf("impossible\n");
- else
- printf("%f\n",C[1]/(1-A[1]));
- }
- return 0;
- }
版权声明:本文博客原创文章,博客,未经同意,不得转载。
hdu 4035 Maze(期待更多经典的树DP)的更多相关文章
- 【HDU 5647】DZY Loves Connecting(树DP)
pid=5647">[HDU 5647]DZY Loves Connecting(树DP) DZY Loves Connecting Time Limit: 4000/2000 MS ...
- 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< ...
- hdu 4035 Maze 概率DP
题意: 有n个房间,由n-1条隧道连通起来,实际上就形成了一棵树, 从结点1出发,开始走,在每个结点i都有3种可能: 1.被杀死,回到结点1处(概率为ki) ...
- HDU 4035 Maze(树形概率DP)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4035 题意:一棵树,从结点1出发,在每个结点 i 都有3种可能:(1)回到结点1 , 概率 Ki:(2 ...
- HDU 4035 Maze 概率dp,树形dp 难度:2
http://acm.hdu.edu.cn/showproblem.php?pid=4035 求步数期望,设E[i]为在编号为i的节点时还需要走的步数,father为dfs树中该节点的父节点,son为 ...
- HDU.4035.Maze(期望DP)
题目链接 (直接)设\(F(i)\)为在\(i\)点走出迷宫的期望步数.答案就是\(F(1)\). 令\(p_i=1-k_i-e_i\),表示\(i\)点沿着边走的概率:\(d_i=dgr[i]\), ...
- HDU 4035 Maze 概率DP 搜索
解题报告链接: http://www.cnblogs.com/kuangbin/archive/2012/10/03/2711108.html 先推公式,设计状态,令DP[i]表示在房间i退出要走步数 ...
- HDU 2059 龟兔赛跑(超级经典的线性DP,找合适的j,使得每个i的状态都是最好的)
龟兔赛跑 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit Status ...
- hdu 2196 叶子节点最长距离(树DP)
http://www.cnblogs.com/kuangbin/archive/2012/08/28/2659915.html 求每个节点到叶子节点的最长距离 需要保存每个节点到叶子节点距离的最大值和 ...
随机推荐
- ASP.NET之Cookie(坑爹的Response.Cookies.Remove)
原文:ASP.NET之Cookie(坑爹的Response.Cookies.Remove) 在web开发中Cookie是必不可少的 .NET自然也有一个强大的Cookie操作类,我们用起来也非常方便, ...
- WPF MediaElement播放器2
在此问个问题,MediaElement播放本地和http上的视频没问题,但是ftp的怎么在本例中播放不了 若高手了解,请不吝赐教 using System; using System.Collecti ...
- Windows Phone开发(23):启动器与选择器之CameraCaptureTask和PhotoChooserTask
原文:Windows Phone开发(23):启动器与选择器之CameraCaptureTask和PhotoChooserTask 这两个组件都属于选择器,而且它们也有很多相似的地方,最明显的上一点, ...
- 图像特效——摩尔纹 moir
%%% Moir %%% 摩尔纹 clc; clear all; close all; addpath('E:\PhotoShop Algortihm\Image Processing\PS Algo ...
- HDU1698_Just a Hook(线段树/成段更新)
解题报告 题意: 原本区间1到n都是1,区间成段改变成一个值,求最后区间1到n的和. 思路: 线段树成段更新,区间去和. #include <iostream> #include < ...
- 【原创】leetCodeOj --- Word Ladder II 解题报告 (迄今为止最痛苦的一道题)
原题地址: https://oj.leetcode.com/submissions/detail/19446353/ 题目内容: Given two words (start and end), an ...
- Oracle GoldenGate (以下简称ogg)在异种移植os同一种db之间的数据同步。
Oracle GoldenGate (以下简称ogg)在异种移植os同一种db之间的数据同步. ogg要实现的功能: 同步可以细化到单个表,满足特定的where条件rows同步,称号column同步. ...
- gradle下载(转)
http://services.gradle.org/distributions services.gradle.org/ distributions/ gradle-2.2.1-rc-1-all.z ...
- linux、hdfs、hive、hbase经常使用的命令
linux经常使用命令 pwd 查看当前工作文件夹的绝对路径 cat input.txt 查看input.txt文件的内容 ls 显示当前文件夹下全部的文件及子文件夹 rm recommender-d ...
- c#错误捕获如何定位到某一行?
e.ToString()在调试版本的程序(并且有pdb文件)的情况下会输出源代码行.