/*#include <stdio.h>
#include <string.h>
int arr[101][101]={},a,s;
void dfs(int i,int j)
{
if(i<1 || i>a || j<1 || j>s || arr[i][j]==0) return;
arr[i][j]=0;
dfs(i-1,j);
dfs(i+1,j);
dfs(i,j-1);
dfs(i,j+1);
}
void dfs2(int i,int j)
{
if(i<1 || i>a || j<1 || j>s || arr[i][j]==1) return;
arr[i][j]=1;
dfs2(i-1,j);
dfs2(i+1,j);
dfs2(i,j-1);
dfs2(i,j+1);
}
int main()
{
int i,j,cnt=0,cut=0;
scanf("%d %d",&a,&s);
int tmp[101][101]={};
for(i=1;i<=a;i++)
{
for(j=1;j<=s;j++)
{
scanf("%d",&arr[i][j]);
tmp[i][j]=arr[i][j];
}
}
for(i=1;i<=a;i++)
{
for(j=1;j<=s;j++)
{
if(arr[i][j]!=0)
{
cnt++;
dfs(i,j);
}
}
}
for(i=1;i<=a;i++)
{
for(j=1;j<=s;j++)
{
arr[i][j]=tmp[i][j];
}
}
for(i=1;i<=a;i++)
{
for(j=1;j<=s;j++)
{
if(arr[i][j]!=1)
{
cut++;
dfs2(i,j);
}
}
}
printf("%d %d",cut,cnt);
return 0;
}*/
#include <stdio.h>
#include <string.h>
int arr[101][101]={},a,s,d;
void dfs(int i,int j,int c)
{
if(i<1 || i>a || j<1 || j>a || arr[i][j]!=c) return;
arr[i][j]=0;
asd++;
dfs(i-1,j,c);
dfs(i+1,j,c);
dfs(i,j-1,c);
dfs(i,j+1,c);
}
int main()
{
int f,g,h,k,n,i,j,cnt=0,sum=0;
scanf("%d %d %d",&a,&s,&d);
for(n=1;n<=d;n++)
{
scanf("%d %d %d %d",&f,&g,&h,&k);
for(i=f;i<h;i++)
{
for(j=g;j<k;j++)
{
arr[i][j]=1;
}
}
}
// for(i=0;i<s;i++)
// {
// for(j=0;j<a;j++)
// {
// printf("%d ",arr[i][j]);
// }
// printf("\n");
// }
// arr에서 0에 대한 dfs를 하자.
return 0;
}