#include<bits/stdc++.h>
using namespace std;
const unsigned int N=1e3+6;
unsigned int g[N][N];
unsigned int s=1,n,m;
unsigned int p,q,t;
unsigned int inf=pow(2,31)-1,ans;
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(i==j) g[i][j]=0;
else g[i][j]=inf;
}
}
for(int i=1;i<=m;i++){
cin>>p>>q>>t;
g[p][q]=min(g[p][q],t);
}
for(int k=2;k<=n;k++){
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(g[i][j]>g[i][k]+g[k][j]){
g[i][j]=g[i][k]+g[k][j];
}
}
}
}
for(int i=2;i<=n;i++){
ans+=g[1][i];
ans+=g[i][1];
}
cout<<ans;
return 0;
}