Pagini recente » Cod sursa (job #2170499) | Cod sursa (job #913563) | Cod sursa (job #848098) | Cod sursa (job #1871583) | Cod sursa (job #2789310)
#include<fstream>
#include<vector>
#include<bitset>
#include<queue>
using namespace std;
ifstream fin("mesaj4.in");
ofstream fout("mesaj4.out");
vector<vector<int>>v;
bitset <100000>ap;
vector<pair<int,int>>pereche;
void BFS(int start)
{
queue<int>Q;
Q.push(start);
ap[start] = true;
while(!Q.empty())
{
int actual = Q.front();
Q.pop();
for(int i = 0; i < v[actual].size(); i++)
{
if(ap[v[actual][i]] == false)
{
ap[v[actual][i]] = true;
pereche.push_back({actual, v[actual][i]});
Q.push(v[actual][i]);
}
}
}
}
int main()
{
ios_base::sync_with_stdio(false);
fin.tie(NULL); fout.tie(NULL);
int X, U;
fin >> X >> U;
v.resize(X);
for(int i = 0; i < U ; i++)
{
int V1, V2;
fin >> V1 >> V2;
V1--, V2--;
v[V1].push_back(V2);
v[V2].push_back(V1);
}
BFS(false);
if(pereche.size() == X - 1)
{
fout << 2 * X - 2 << '\n';
for(int i = X - 2; i >= 0; i--)
{
fout << pereche[i].second + 1 << ' ' << pereche[i].first + 1 << '\n';
}
for(int i = 0; i < X - 1; i++)
{
fout << pereche[i].first + 1 << " " << pereche[i].second + 1 << '\n';
}
}
else
{
fout << -1;
}
return false;
}