藏宝图

问题 C: 藏宝图

时间限制: 2 Sec  内存限制: 256 MB

题目描述

Czy爬上黑红树,到达了一个奇怪的地方……

Czy发现了一张奇怪的藏宝图。图上有n个点,m条无向边。已经标出了图中两两之间距离dist。但是czy知道,只有当图刚好又是一颗树的时候,这张藏宝图才是真的。如果藏宝图是真的,那么经过点x的边的边权平均数最大的那个x是藏着宝物的地方。请计算这是不是真的藏宝图,如果是真的藏宝之处在哪里。


输入

输入数据第一行一个数T,表示T组数据。

对于每组数据,第一行一个n,表示藏宝图上的点的个数。

接下来n行,每行n个数,表示两两节点之间的距离。

输出

输出一行或两行。第一行”Yes”或”No”,表示这是不是真的藏宝图。

若是真的藏宝图,第二行再输出一个数,表示哪个点是藏宝之处。

样例输入

230 7 97 0 29 2 030 2 72 0 97 9 0

样例输出

Yes1Yes3样例解释:第一棵树的形状是1--2--3。1、2之间的边权是7,2、3之间是2。 第二棵树的形状是2--1--3。2、1之间的边权是2,1、3之间是7。

提示


对于30%数据,n<=50,1<=树上的边的长度<=10^9。



对于50%数据,n<=600.



对于100%数据,1<=n<=2500,除30%小数据外任意0<=dist[i][j]<=10^9,T<=5


最小生成树

#include<iostream>
#include<cmath>
#include<cstring>
#include<cstdio>
#include<set>
#include<deque>
#include<cstdlib>
#include<algorithm>
#define V 2505
#define mod 1000000007
#define LL long long
using namespace std;
int n,m,vis[V];
int rt;
LL mx;
LL a[V][V],d[V];
int ts;
int f[V],is[V],ans;
LL it[V];
struct da
{
   int to,next;      
}Edge[V*5];
int head[V],tot;
inline void add( int x, int y)
{
   Edge[tot].to=y;
   Edge[tot].next=head[x];
   head[x]=tot++;      
}
inline void dd()
{
    memset (d,127, sizeof (d));
    d[1]=0;
   while (1)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值