#include<iostream>
#include<algorithm>
using namespace std;
int n,m;
int num;
int fa[5005];
struct node{
int u,v,w;
}g[200005];
void add(int u,int v,int w){
g[num++].u=u;
g[num].v=v;
g[num].w=w;
}
bool cmp(node a,node b){
return a.w<b.w;
}
int find(int x){
if(fa[x]==x){
return x;
}
return fa[x]=find(fa[x]);
}
void merge(int x,int y){
int fx=find(x);
int fy=find(y);
if(fx!=fy){
fa[fx]=fy;
}
}
int ans,cnt;
int main(){
cin>>n>>m;
for(int i=1;i<=m;i++){
int u,v,w;
cin>>u>>v>>w;
add(u,v,w);
}
sort(g+1,g+1+m,cmp);
for(int i=1;i<=n;i++){
fa[i]=i;
}
for(int i=1;i<=m;i++){
if(find(g[i].u)==find(g[i].v)){
continue;
}else{
merge(g[i].u,g[i].v);
}
ans+=g[i].w;
cnt++;
if(cnt==n-1){
cout<<ans;
return 0;
}
}
cout<<"orz";
return 0;
}