思路:求最大值时如果空座位连的数量是奇数则x/2+1,是偶数则x/2。求最小值时每三个空座位坐一个人这样值最小。
#include<bits/stdc++.h>
using namespace std;
int map1[1005][1005],x,y,m,sum1,sum2,ans;
void dfs(int i,int j)
{
if(j==y)
return;
if(!map1[i][j])
{
ans++;
map1[i][j]=1;
dfs(i,j+1);
}
return;
}
int main()
{
int t,a,b,case1=1;
scanf("%d",&t);
while(t--)
{
sum1=0;
sum2=0;
memset(map1,0,sizeof(map1));
cin>>x>>y;
cin>>m;
while(m--)
{
cin>>a>>b;
map1[a][b]=1;
}
for(int i=0;i<x;i++)
{
for(int j=0;j<y;j++)
{
if(!map1[i][j])
{
ans=0;
dfs(i,j);
if(ans==1)
{
sum1+=ans;
sum2+=ans;
}
else
{
if(ans%2==0)
{
sum1+=ans/2;
}
else
{
sum1+=ans/2+1;
}
if(ans%3==0)
{
sum2+=ans/3;
}
else
{
sum2+=ans/3+1;
}
}
}
}
}
printf("Case #%d: %d %d\n",case1,sum1,sum2);
case1++;
}
return 0;
}
343

被折叠的 条评论
为什么被折叠?



