#include<cstdio>
#include<cstring>
#define MAX_N 1016
#define MIN(x,y) ((x)>(y)?(y):(x))
using namespace std;
int map[MAX_N][MAX_N];
int d[MAX_N];
int vis[MAX_N];
int n;
void dijkstra(int s)
{
memset(vis,0,sizeof(vis));
for(int i=1;i<=n;i++)
{
d[i]=map[1][i];
}
d[1]=0;
vis[1]=1;
while(1)
{
int v=-1;
for(int i=1;i<=n;i++)
{
if(!vis[i]&&(v==-1||d[i]>d[v]))
v=i;
}
if(v==-1)
break;
vis[v]=1;
for(int i=1;i<=n;i++)
{
if(d[i]<MIN(d[v],map[v][i]))
d[i]=MIN(d[v],map[v][i]);
}
}
}
int main()
{
int T,m,t=1;
scanf("%d",&T);
while(T--)
{
memset(map,0,sizeof(map));
scanf("%d%d",&n,&m);
for(int i=0;i<m;i++)
{
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
map[a][b]=c;
map[b][a]=c;
}
dijkstra(1);
printf("Scenario #%d:\n%d\n\n",t++,d[n]);
}
}
poj 1797 最大生成树 (最短路也可以做)
最新推荐文章于 2018-10-16 18:58:00 发布