概述
#include <bits/stdc++.h>
using namespace std;
#define ll long long
const int maxn=10010;
struct node
{
int v,w;
}a,b;
vector<node>tree[maxn];
int sum[maxn],n;
ll dp[maxn];
void dfs(int cur,int fa)
{
sum[cur]=1;
for(int i=0;i<tree[cur].size();i++)
{
int son=tree[cur][i].v;
ll len=tree[cur][i].w;
if(son==fa) continue;
dfs(son,cur);
sum[cur]+=sum[son];
dp[cur]+=dp[son]+(n-sum[son])*sum[son]*len;
}
}
int main()
{
int t,x,y,z;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(int i=0;i<n;i++)
tree[i].clear();
memset(sum,0,sizeof(sum));
memset(dp,0,sizeof(dp));
for(int i=1;i<n;i++)
{
scanf("%d%d%d",&x,&y,&z);
a.v=x;
a.w=b.w=z;
b.v=y;
tree[x].push_back(b);
tree[y].push_back(a);
}
dfs(0,-1);
printf("%fn",dp[0]*2.0/n/(n-1));
}
return 0;
}
最后
以上就是聪明马里奥为你收集整理的树上顶点的平均距离的全部内容,希望文章能够帮你解决树上顶点的平均距离所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复