Pagini recente » Cod sursa (job #367379) | Cod sursa (job #320608) | Borderou de evaluare (job #2238963) | Cod sursa (job #1222790) | Cod sursa (job #2653015)
#include <fstream>
#include <algorithm>
using namespace std;
ifstream fin("apm.in");
ofstream fout("apm.out");
int n,m,a[400004],s,m1,v1[400004];
struct graf
{
int x,y,c;
};
bool cmp(graf x, graf y)
{
if(x.c!=y.c)
return x.c<y.c;
if(x.x!=y.x)
return x.x<y.x;
if(x.y!=y.y)
return x.y<y.y;
}
graf v[400004];
int arad(int x)
{
while(a[x]!=0)
x=a[x];
return x;
}
int main()
{
fin>>n>>m;
for(int i=1;i<=m;i++)
fin>>v[i].x>>v[i].y>>v[i].c;
sort(v+1,v+m+1,cmp);
for(int i=1;i<=m;i++)
{
int rx=arad(v[i].x);
int ry=arad(v[i].y);
if(rx==ry)
continue;
s+=v[i].c;
v1[++m1]=i;
if(a[rx]<a[ry])
{
a[rx]+=a[ry];
a[ry]=rx;
}
else
{
a[ry]+=a[rx];
a[rx]=ry;
}
}
fout<<s<<"\n"<<m1<<"\n";
for(int i=1;i<=m1;i++)
fout<<v[v1[i]].y<<" "<<v[v1[i]].x<<"\n";
return 0;
}