Pagini recente » Cod sursa (job #2372340) | Cod sursa (job #1843584) | Cod sursa (job #844860) | Cod sursa (job #2041369) | Cod sursa (job #1915741)
#include <iostream>
#include <fstream>
#include <vector>
#include <queue>
#define DM 200005
using namespace std;
ifstream fin("apm.in");
ofstream fout("apm.out");
int n, m, a, b, c, arb[DM], cost_total;
vector<pair<int, int> > g[DM];
priority_queue<pair<int, pair<int, int > > > pq;
bool viz[DM];
void make_apm()
{
pq.push(make_pair(0, make_pair(1, 0)));
while(!pq.empty())
{
int nod = pq.top().second.first;
int venit_din = pq.top().second.second;
int cost = -pq.top().first;
pq.pop();
if(!viz[nod])
{
viz[nod] = 1;
arb[nod] = venit_din;
cost_total += cost;
for(auto it : g[nod])
if(!viz[it.first])
pq.push(make_pair(-it.second, make_pair(it.first, nod)));
}
}
}
int main()
{
fin >> n >> m;
for(int i = 1; i <= m; i++)
{
fin >> a >> b >> c;
g[a].push_back(make_pair(b, c));
g[b].push_back(make_pair(a, c));
}
make_apm();
fout << cost_total << '\n' << n - 1 << '\n';
for(int i = 2; i <= n; i++)
fout<< i << ' ' << arb[i] << '\n';
return 0;
}