标签:
2 4 4 1 2 1 2 3 1 3 4 1 1 4 0 5 6 1 2 1 1 3 1 1 4 1 1 5 1 3 5 1 4 2 1
Case #1: Yes Case #2: No
即可行的白边数为 ans = Min+n , 因为 0 <= n <=Max-Min ,所以 Min <= ans <=Max 。
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstring>
using namespace std;
const int maxn=100010;
const int N=30;
struct edge
{
int u,v,val;
} a[maxn];
int id[maxn],f[N]= {0,1,2},n,m,T;
bool cmp1(edge p,edge q)
{
return p.val<q.val;
}
bool cmp2(edge p,edge q)
{
return p.val>q.val;
}
int Find(int x)
{
if(x!=id[x]) id[x]=Find(id[x]);
return id[x];
}
void input()
{
scanf("%d %d",&n,&m);
for(int i=0; i<m; i++) scanf("%d %d %d",&a[i].u,&a[i].v,&a[i].val);
}
int kru()
{
for(int i=0; i<maxn; i++) id[i]=i;
int res=0,num=0;
for(int i=0; i<m; i++)
{
int p=Find(a[i].u),q=Find(a[i].v);
if(p!=q)
{
id[p]=q;
res+=a[i].val;
}
}
for(int i=1; i<=n; i++) if(Find(i)==i) num++;
if(num>1) return -1;
return res;
}
void solve(int co)
{
int l,r;
sort(a,a+m,cmp1);
l=kru();
sort(a,a+m,cmp2);
r=kru();
if(l==-1 || r==-1)
{
printf("Case #%d: No\n",co);
return ;
}
else
{
for(int i=1; i<N; i++)
{
if(f[i]>=l && f[i]<=r)
{
printf("Case #%d: Yes\n",co);
return ;
}
}
printf("Case #%d: No\n",co);
}
}
int main()
{
for(int i=3; i<N; i++) f[i]=f[i-1]+f[i-2];
scanf("%d",&T);
for(int co=1; co<=T; co++)
{
input();
solve(co);
}
return 0;
}
hdu 4786 Fibonacci Tree ( 最小生成树 )
标签:
原文地址:http://blog.csdn.net/u012596172/article/details/43195993