#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define REP(i,a,b) for(int i=(a);i<=(b);i++) #define PER(i,a,b) for(int i=(a);i>=(b);i--) #define RVC(i,S) for(int i=0;i<(S).size();i++) #define RAL(i,u) for(int i=fr[u];i!=-1;i=e[i].next) using namespace std; typedef long long LL; typedef pair pii; template inline void read(T& num) { bool start=false,neg=false; char c; num=0; while((c=getchar())!=EOF) { if(c=='-') start=neg=true; else if(c>='0' && c<='9') { start=true; num=num*10+c-'0'; } else if(start) break; } if(neg) num=-num; } /*============ Header Template ============*/ const int maxn=3005; int fa[maxn],va[maxn]; int n,m; int Find(int x) { return fa[x]==x?x:fa[x]=Find(fa[x]); } void solve() { int cnt=n; REP(i,1,n) fa[i]=i,va[i]=0; REP(i,1,m) { int u,v,w; read(u);read(v);read(w); if(u!=v) va[u]+=w,va[v]+=w; u=Find(u); v=Find(v); if(u!=v) cnt--,fa[u]=v; } int ret=(int)(1e9); if(cnt>1) printf("0\n"); else { REP(i,1,n) ret=min(ret,va[i]); printf("%d\n", ret); } } int main() { while(scanf("%d%d",&n,&m)==2) solve(); return 0; }