Pagini recente » Cod sursa (job #3297370) | Cod sursa (job #2427679) | Cod sursa (job #3297487) | Cod sursa (job #3297415) | Cod sursa (job #3297319)
#include <bits/stdc++.h>
using namespace std;
const int NMAX = 100000;
vector <int> edges[NMAX + 1];
int p[NMAX + 1];
int viz[NMAX + 1];
bool repair( int node ) {
if ( viz[node] ) return false;
viz[node] = true;
for ( auto vec : edges[node] ) {
if ( !p[vec] || repair( p[vec] ) ) {
p[node] = vec;
p[vec] = node;
return true;
}
}
return false;
}
int main() {
ifstream fin( "cuplaj.in" );
ofstream fout( "cuplaj.out" );
int n, m, e;
fin >> n >> m >> e;
for ( int i = 1, a, b; i <= e; i ++ ) {
fin >> a >> b;
edges[a].push_back( b + n );
}
int cuplaj = 0;
bool ok = true;
while ( ok ) {
ok = false;
for ( int i = 1; i <= n; i ++ ) viz[i] = false;
for ( int i = 1; i <= n; i ++ ) {
if ( !p[i] && repair( i ) ) {
cuplaj ++;
ok = true;
}
}
}
fout << cuplaj << '\n';
for ( int i = 1; i <= n; i ++ ) {
if ( p[i] ) {
fout << i << ' ' << p[i] - n << '\n';
}
}
return 0;
}