看到这个题想到之前周赛做过两遍的同样是粉刷的那个题==套啊套,依旧没找对方法 示例都不对 主要原因是这个题是斜着的orz有些点不出现在交线上
怎么办?题解告诉我 我又读错题了……你什么时候能细心点??? \是红色 /是蓝色 而且是矩形不是正方形!能不能长点心???
方法跟粉刷一点都不一样 呵呵
对于'\',如果当前格子为红色或者绿色,前一个格子(斜线上的)既不是红色也不是绿色,则必然要刷一次。同理,'/'上的也是。
#include <iostream>
#include<cstring>
#include<cstdio>
using namespace std;
char str[60][60];
int t,n,m;
int main()
{
// freopen("cin.txt","r",stdin);
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
for(int i=0;i<n;i++) scanf("%s",str[i]);
int m=strlen(str[0]);//这里超级坑爹啊 还有可能是一行的 所以str[1] WA了好几次
int ans=0;
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
if(str[i][j]=='R'||str[i][j]=='G')
{
if(!(str[i-1][j-1]=='R'||str[i-1][j-1]=='G')) ans++;
}
}
}
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
if(str[i][j]=='B'||str[i][j]=='G')
{
if(!(str[i-1][j+1]=='B'||str[i-1][j+1]=='G')) ans++;
}
}
}
printf("%d\n",ans);
}
return 0;
}