
3 3 0 1 3 0 2 2 1 2 5 3 0 2 3 1 2 6 0 1 6 0 0
6.0000HintThe initial minimal cost is 5 by connecting city 0 to 1 and city 0 to 2. In the first suspicious case, the minimal total cost is increased to 6; the second case remains 5; the third case is increased to 7. As the result, the expected cost is (5+6+7)/3 = 6.
#include<stdio.h>
#include<vector>
#include<algorithm>
using namespace std;
const int N = 3005;
const double inf = 0x3f3f3f3f;
struct EDG
{
int u,v;
double c;
};
struct TO
{
int v;
double c;
};
vector<TO>tmap[N];
EDG edg[N];
int n,treeEdg[N][N];
double node[N];
EDG tedg[N*N];
int fath[N];
int cmp(EDG a,EDG b)
{
return a.c<b.c;
}
int findfath(int x)
{
if(x==fath[x])
return fath[x];
fath[x]=findfath(fath[x]);
return fath[x];
}
double MST(int m)
{
double sum=0;
int k=0;
for(int i=0; i<m; i++)
{
int x=findfath(tedg[i].u);
int y=findfath(tedg[i].v);
if(x!=y)
{
k++;
treeEdg[tedg[i].u][tedg[i].v]=treeEdg[tedg[i].v][tedg[i].u]=k;
edg[k].u=tedg[i].u; edg[k].v=tedg[i].v; edg[k].c=tedg[i].c;
fath[x]=y; sum+=tedg[i].c;
if(k==n-1)
break;
}
}
return sum;
}
int main()
{
int m,q,a,b;
double c,ans,sum,tc;
TO ss;
while(scanf("%d%d",&n,&m)>0&&n+m!=0)
{
for(int i=0;i<=n;i++)
{
fath[i]=i;
for(int j=0;j<=n;j++)
treeEdg[i][j]=N;
}
for(int i=0;i<m;i++)
{
scanf("%d%d%lf",&a,&b,&c);
tedg[i].u=a;
tedg[i].v=b;
tedg[i].c=c;
}
sort(tedg,tedg+m,cmp);
sum=MST(m);
scanf("%d",&q);
ans=0;
for(int j=0;j<q;j++)
{
scanf("%d%d%lf",&a,&b,&c);
if(treeEdg[a][b]==N)
ans+=sum;
else
{
for(int i=0;i<=n;i++)
fath[i]=i;
for(int i=1;i<n;i++)
{
if(treeEdg[a][b]==i)
{
tc=edg[i].c; continue;
}
int x=findfath(edg[i].u);
int y=findfath(edg[i].v);
fath[x]=y;
}
int flag=0;
for(int i=0;i<m&&tedg[i].c<c;i++)
{
if(treeEdg[tedg[i].u][tedg[i].v]!=N)
continue;
int x=findfath(tedg[i].u);
int y=findfath(tedg[i].v);
fath[x]=y;
x=findfath(a);
y=findfath(b);
if(x==y)
{
ans=ans+sum-tc+tedg[i].c; flag=1; break;
}
}
if(flag==0)
ans=ans+sum-tc+c;
}
}
printf("%.4lf\n",ans/(q*1.0));
}
}
HDU4126Genghis Khan the Conqueror(最小生成树+并查集)
原文地址:http://blog.csdn.net/u010372095/article/details/44495541