Pagini recente » Cod sursa (job #842645) | Cod sursa (job #2289783) | Cod sursa (job #2907845) | Cod sursa (job #3185949) | Cod sursa (job #643166)
Cod sursa(job #643166)
#include <cstdio>
#include <vector>
using namespace std;
#define file_in "mesaj4.in"
#define file_out "mesaj4.out"
#define nmax 101000
int N,M;
int a,b,nr,i;
int x[nmax];
int y[nmax];
int viz[nmax];
vector<int> G[nmax];
void dfs(int nod){
if (viz[nod])
return ;
viz[nod]=1;
vector<int> :: iterator it;
for (it=G[nod].begin();it!=G[nod].end();++it)
if (!viz[*it]){
x[++nr]=nod;
y[nr]=*it;
dfs(*it);
}
}
int main(){
freopen(file_in,"r",stdin);
freopen(file_out,"w",stdout);
scanf("%d %d", &N,&M);
for (i=1;i<=M;++i){
scanf("%d %d", &a, &b);
G[a].push_back(b);
G[b].push_back(a);
}
nr=0;
dfs(1);
printf("%d\n", 2*N-2);
for (i=1;i<N;++i)
printf("%d %d\n", x[i], y[i]);
for (i=N-1;i>=1;--i)
printf("%d %d\n", y[i],x[i]);
return 0;
}