Pagini recente » Cod sursa (job #407744) | Cod sursa (job #2802740) | Cod sursa (job #2019117) | Rating Krisztian Kiss (kkriszel) | Cod sursa (job #2640964)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("felinare.in");
ofstream fout("felinare.out");
vector <int> v[10000];
int l[10000], r[10000], fst[10000], fdr[10000];
bool viz[10005];
int ans = 0;
int n, m;
bool pairup(int node)
{
if(viz[node] == 1)
return false;
viz[node] = 1;
for(int i = 0; i < v[node].size(); i++)
if(r[v[node][i]] == 0)
{
ans++;
l[node] = v[node][i];
r[v[node][i]] = node;
return true;
}
for(int i = 0; i < v[node].size(); i++)
if(pairup(r[v[node][i]]) != 0)
{
l[node] = v[node][i];
r[v[node][i]] = node;
return true;
}
return false;
}
void dfs(int node)
{
viz[node] = 1;
fst[node] = 0;
for(int i = 0; i < v[node].size(); i++)
if(viz[r[v[node][i]]] == 0)
{
fdr[v[node][i]] = 1;
dfs(r[v[node][i]]);
}
}
int main()
{
fin >> n >> m;
for(int i = 1; i <= m; i++)
{
int x, y;
fin >> x >> y;
v[x].push_back(y);
}
bool ok = true;
while(ok == true)
{
ok = false;
fill(viz, viz + n + 1, 0);
for(int i = 1; i <= n; i++)
if(l[i] == 0)
ok |= pairup(i);
}
fout << 2 * n - ans << '\n';
for(int i = 1; i <= n; i++)
if(l[i] != 0)
fst[i] = 1;
fill(viz, viz + n + 1, 0);
for(int i = 1; i <= n; i++)
if(l[i] == 0)
dfs(i);
for(int i = 1; i <= n; i ++)
{
int sum = 0;
if(fst[i] == 0)
sum++;
if(fdr[i] == 0)
sum += 2;
fout << sum << '\n';
}
return 0;
}