题意:有一个棋盘n行,列数不超过50,用red和blue给这个棋盘涂色,每个格子每种颜色最多涂一次,如果两种颜色都涂了则该格子颜色为Green;red以斜杠‘\‘方式涂色,bule以’/‘方式涂色。给出涂色后的棋盘,问最少涂了几次。
思路:搜索的思路没错,不过这题有点小坑,题目只告诉了行,并没有明确列,所以得自己求出。涂色时并不是一涂到底,也可以连续几个对角的格子涂色。所以不管是暴力枚举还是搜索都行。
const int N=100+5;
char s[N][N];
int n,m;
void dfs(int x,int y,char c)
{
if(s[x][y]=='.') return ;//隔断了,不用往下涂色了
if(s[x][y]==c)
{
s[x][y]='.';
if(c=='B')
{
if(x+1<n&&y-1>=0) dfs(x+1,y-1,c);//反斜杠方向涂色
}
else
{
if(x+1<n&&y+1<m) dfs(x+1,y+1,c);
}
}
else
{
if(s[x][y]!='G') return ;
else
{
if(c=='B')
{
s[x][y]='R';//清楚标记,换另一个方向涂色
if(x+1<n&&y-1>=0) dfs(x+1,y-1,c);
}
else
{
s[x][y]='B';
if(x+1<n&&y+1<m) dfs(x+1,y+1,c);
}
}
}
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(int i=0; i<n; i++)
scanf("%s",s[i]);
m=strlen(s[0]);
int ans=0;
for(int i=0; i<n; i++)
for(int j=0; j<m; j++)
if(s[i][j]!='.')
{
if(s[i][j]=='G')
{
ans+=2;
dfs(i,j,'B');
dfs(i,j,'R');
}
else
{
ans++;
if(s[i][j]=='B') dfs(i,j,'B');
if(s[i][j]=='R') dfs(i,j,'R');
}
}
printf("%d\n",ans);
}
return 0;
}