#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define ii pair <int,int>
#define F first
#define S second
#define ever (;;)
const int N = 100100;
int n,m,k,freq[N],num,ans,cum[N],mx,Get[N];
vector <int> vr[N],vl[N],v;
map <ii,int> mp;
int main()
{
scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=k;i++)
{
int a,b;
scanf("%d%d",&a,&b);
vl[a].push_back(b);
vr[b].push_back(a);
freq[a]++;
}
for(int i=1;i<=n;i++)
{
if( freq[i] == 2 )
{
int x = vl[i][0];
int y = vl[i][1];
mp[ { x , y } ]++;
}
}
for(int i=1;i<=n;i++)
num += ( freq[i] >= 1 );
ans = num;
for(int i=1;i<=m;i++)
{
int curr = num+1;
for(auto &x:vr[i])
Get[i] += ( freq[x] == 1 );
ans = min( ans , num+1-Get[i] );
}
for(auto &X:mp)
{
int x = X.F.F;
int y = X.F.S;
int c = X.S;
ans = min( ans , num+2 - c - Get[x] - Get[y] );
}
printf("%d\n",ans);
}
Copy