// compile: g++ -o data data.cpp -std=gnu++20 -DLOCAL -g
// run: ./data < data.in
#include <bits/stdc++.h>
#pragma GCC optimize("O3,unroll-loops")
#pragma GCC target("avx2,bmi,bmi2,lzcnt,popcnt")
#ifdef LOCAL
#endif
#define sz(v) ((int)(v).size())
#define PV(v) for (int i=0;i<v.size();++i)cout<<v[i]<<" ";cout<<endl;
#define OK cout<<"OK"<<endl;
#define INTINF 9223372036854775807
#define int long long
#define MAXN 100010
using namespace std;
int n, m;
vector<int> e[MAXN];
vector<int> c[MAXN];
int vis[MAXN];
int cnt = 0;
void dfs(int u, int k) {
    vis[u] = 1;
    c[k].push_back(u);
    for (int v: e[u]) {
        if (vis[v]) continue;
        dfs(v, k);
    }
}
int32_t main() {
    ios::sync_with_stdio(false); cin.tie(nullptr); cout.tie(nullptr);
    cin >> n >> m;
    for (int i = 0; i < m; ++i) {
        int u, v; cin >> u >> v;
        e[u].push_back(v);
        e[v].push_back(u);
    }
    for (int i = 1; i <= n; ++i) {
        if (!vis[i]) dfs(i, cnt++);
    }
    cout << cnt - 1 << endl;
    for (int i = 0; i < cnt-1; ++i) {
        cout << c[i][0] << " " << c[i+1][0] << endl;
    }
    return 0;
}
					No Comments