Pagini recente » Cod sursa (job #2820904) | Cod sursa (job #2962584) | Cod sursa (job #2112802) | Cod sursa (job #2490413) | Cod sursa (job #2884255)
#include <bits/stdc++.h>
using namespace std;
const int N = 1e4 + 5;
vector <int> g[N];
int loverG[N], loverB[N], viz[N];
int n, m, e;
int bkt(int nod)
{
if (viz[nod])
return 0;
viz[nod] = 1;
for (auto vecin : g[nod])
{
if (!loverG[vecin] || bkt(loverG[vecin]))
{
loverG[vecin] = nod;
loverB[nod] = vecin;
return 1;
}
}
return 0;
}
int main()
{
freopen("cuplaj.in", "r", stdin);
freopen("cuplaj.out", "w", stdout);
cin >> n >> m >> e;
for (int i = 1; i <= e; i++)
{
int a, b;
cin >> a >> b;
g[a].push_back(b);
//g[b].push_back(a);
}
while (true)
{
for (int i = 1; i <= n; i++)
viz[i] = 0;
int nr = 0;
for (int i = 1; i <= n; i++)
if (!loverB[i])
nr += bkt(i);
if (!nr)
break;
}
int ans = 0;
for (int i = 1; i <= n; i++)
ans += (loverB[i] != 0);
cout << ans << '\n';
for (int i = 1; i <= n; i++)
if (loverB[i])
cout << i << " " << loverB[i] << '\n';
return 0;
}