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

###题目:

[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;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值