模板参考蓝书
参考题解HDU 4738
#include<stdio.h>
#include<stdlib.h>
#include<algorithm>
#include<string.h>
#define ll long long
#define MAXN 10010
#define INF 0X3f3f3f3f
#include<iostream>
#include<vector>
#include<stack>
const ll inf=1e18;
using namespace std;
int n,m;
int edge[MAXN][MAXN];
vector<int> X[MAXN];
int ans=INF;
int dfs_clock;
int pre[MAXN];
int low[MAXN];
//bool iscut[MAXN];
int dfs(int u,int fa){
int lowu=pre[u]=++dfs_clock;
// printf("到达%d \n",u);
int child=0;
for(int i=0;i<X[u].size();i++){
int v=X[u][i];
if(!pre[v]){
child++;
int lowv=dfs(v,u);
lowu=min(lowu,lowv);
// if(lowv>=pre[u]){
//iscut[u]=true;
if(lowv>pre[u]){
if(edge[u][v]<ans) ans=edge[u][v];
// }
}
}
else if(pre[v]<pre[u] && v!=fa){
lowu=min(lowu,pre[v]);
}
// if(fa<0 && child==1) iscut[u]=0;
}
low[u]=lowu;
return lowu;
}
bool vis[MAXN][MAXN];
void init(){
dfs_clock=0;
ans=INF;
for(int i=1;i<=n;i++){
pre[i]=0;
low[i]=0;
X[i].clear();
// iscut[i]=false;
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
vis[i][j]=false;
}
}
}
int main(){
while(1){
scanf("%d%d",&n,&m);
if(n==0&&m==0)return 0;
init();
int a,b,c;
for(int i=1;i<=m;i++){
scanf("%d%d%d",&a,&b,&c);
if(vis[a][b]){
edge[a][b]=INF;
edge[b][a]=INF;
continue;
}
vis[a][b]=true;vis[b][a]=true;
edge[a][b]=c;
edge[b][a]=c;
X[a].push_back(b);
X[b].push_back(a);
}
int cnt=0;
for(int i=1;i<=n;i++){
if(pre[i]==0){
cnt++,dfs(i,-1);
// printf("vertex %d\n",i);
}
}
/*for(int i=1;i<=n;i++){
for(int j=0;j<X[i].size();j++){
printf("from %d to %d value : %d\n",i,X[i][j],edge[i][X[i][j]]);
}*/
// cout << "::::" << cnt << endl;
if(cnt>1){
printf("0\n");
}
else if(ans==INF){
printf("-1\n");
// continue;
}
else{
if(ans==0)printf("1\n");
else printf("%d\n",ans);
}
}
}