转载请注明出处:http://blog.csdn.net/a1dark
分析:这是一道floyd求最小环的模板题、
#include<string.h>
#include<stdio.h>
#include<iostream>
using namespace std;
const int INF=10000000;
const int maxn=102;
int map[maxn][maxn];
int map1[maxn][maxn];
int n,m,minc;
void floyd()
{
minc=INF;
for(int k=1;k<=n;k++)
{
for(int i=1;i<=k;i++)
for(int j=i+1;j<=k;j++)
minc=min(minc,map1[i][j]+map[k][i]+map[k][j]);
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
map1[i][j]=min(map1[i][j],map1[i][k]+map1[k][j]);
}
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
{
map[i][j]=INF;
map1[i][j]=INF;
}
int s,e,w;
for(int i=0;i<m;i++)
{
scanf("%d%d%d",&s,&e,&w);
w=min(map[s][e],w);
map[s][e]=w;
map[e][s]=w;
map1[s][e]=w;
map1[e][s]=w;
}
floyd();
if(minc<INF)
printf("%d\n",minc);
else
printf("It's impossible.\n");
}
return 0;
}