您的位置:首页 > 其它

CF——Codeforces Round #428 (Div. 2)C. Journey

2017-08-16 17:00 316 查看

题目:

[C. Journey](http://codeforces.com/contest/839/problem/C)

题解:

求路径期望,但是每条路径几率不一样,所以每条路径得分别算!

用dfs搜索路径即可,记录并随之更新每条路径的几率。

AC code

#include <bits/stdc++.h>
#define maxn 100000 + 10
typedef long long LL;
using namespace std;
int t = 0;
int n;
double ans = 0;
vector <int> a[maxn];

void dfs(int y,int x,int s,double p)
{

if(a[x].size() <= 1&&x != 1)
{ans += double(s*1.0)*p;return;}
int len =a[x].size();
for(int i = 0; i < len; i++)
if(a[x][i] != y)
if(x!=1) dfs(x,a[x][i],s+1,p*(double)(1.0)/(a[x].size()-1));
else dfs(x,a[x][i],s+1,p*(double)(1.0)/a[x].size());

}

int main()
{
cin >> n;
int u,v;
for(int i = 1; i < n; i++)
{
scanf("%d%d",&u,&v);
a[u].push_back(v);
a[v].push_back(u);
}
dfs(0,1,0,1);

printf("%.15lf\n",ans);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  codeforces dfs 期望