#include<iostream>
#include<queue>
using namespace std;
int n,m,e;
int head[1005],to[200005],net[200005],w[200005],tot=1,cut[1005],dis[1005];
int s,t;
void add(int u,int v,int ww){
net[++tot]=head[u];
head[u]=tot;
cut[u]=tot;
w[tot]=ww;
to[tot]=v;
}
bool bfs(int s){
queue<int>q;
q.push(0);
for(int i=1;i<=n+m+1;i++)
dis[i]=-1;
dis[0]=0;
while(!q.empty()){
int now=q.front();
q.pop();
for(int i=cut[now];i;i=net[i]){
if(dis[to[i]]!=-1||w[i]==0)continue;
dis[to[i]]=dis[now]+1;
q.push(to[i]);
}
}
return dis[t]!=-1;
}
int dfs(int x,int flow){
cout<<x<<endl;
if(x==t)
return flow;
int last=flow;
for(int &i=head[x];i;i=net[i]){
if(dis[to[i]]!=dis[x]+1||w[i]==0)
continue;
int nowflow=dfs(to[i],min(last,w[i]));
last-=nowflow;
w[i]-=nowflow;
w[i^1]+=nowflow;
if(last==0)
break;
}
if(last==flow)
dis[x]=-1;
return flow-last;
}
int main(){
cin>>n>>m>>e;
t=n+m+1;
for(int i=1;i<=e;i++){
int u,v;
cin>>u>>v;
add(u,n+v,1);
add(v+n,u,0);
}
for(int i=1;i<=n;i++){
add(s,i,1);
add(i,s,0);
}
for(int i=1;i<=m;i++){
add(i+n,t,1);
add(t,i+n,0);
}
while(bfs(s)){
for(int i=0;i<=n+m+1;i++){
head[i]=cut[i];
}
s+=dfs(s,100000000);
}
cout<<s;
return 0;
}
```