B. Putting Bricks in the Wall(思维)Codeforces Round #676 (Div. 2)

原题链接:https://codeforces.com/contest/1421/problem/B

B. Putting Bricks in the Wall(思维)Codeforces Round #676 (Div. 2)_第1张图片
测试样例

input
3
4
S010
0001
1000
111F
3
S10
101
01F
5
S0101
00000
01111
11111
0001F
output
1
3 4
2
1 2
2 1
0

题意: 给定一个 n × n n\times n n×n的迷宫,现在 P i n k Pink Pink在起点 ( 1 , 1 ) (1,1) (1,1)处,终点在 ( n , n ) (n,n) (n,n)处, P i n k Pink Pink在开始游戏之前会选择一个数 0 0 0 1 1 1,迷宫的每个格子会存在一个 0 0 0 1 1 1的数字,游戏规则为 P i n k Pink Pink只能走相邻的且格子数为开始游戏前选择的数的格子。现在你最多有两次机会可以改变元素值,问你怎样才使得 P i n k Pink Pink不能走到终点。

解题思路: 这是一道思维题,不用想得很深,我们只需要知道 P i n k Pink Pink一开始走出起点的限制有两个格子 ( 1 , 2 ) (1,2) (1,2)和(2,1),走到终点也有两个格子限制 ( n − 1 , n ) (n-1,n) (n1,n) ( n , n − 1 ) (n,n-1) (n,n1)。那么只要使得这起点格子和终点格子起冲突即可。让这两组的格子元素值相反即可。 我们利用if判断即可得出答案。注意所有情况的考虑。

AC代码

/*
*邮箱:[email protected]
*blog:https://me.csdn.net/hzf0701
*注:文章若有任何问题请私信我或评论区留言,谢谢支持。
*
*/
#include	//POJ不支持

#define rep(i,a,n) for (int i=a;i<=n;i++)//i为循环变量,a为初始值,n为界限值,递增
#define per(i,a,n) for (int i=a;i>=n;i--)//i为循环变量, a为初始值,n为界限值,递减。
#define pb push_back
#define IOS ios::sync_with_stdio(false);cin.tie(0); cout.tie(0)
#define fi first
#define se second
#define mp make_pair

using namespace std;

const int inf = 0x3f3f3f3f;//无穷大
const int maxn = 205;//最大值。
typedef long long ll;
typedef long double ld;
typedef pair<ll, ll>  pll;
typedef pair<int, int> pii;
//*******************************分割线,以上为自定义代码模板***************************************//

int t,n;
char graph[maxn][maxn];
int main(){
     
	//freopen("in.txt", "r", stdin);//提交的时候要注释掉
	IOS;
	while(cin>>t){
     
		while(t--){
     
			cin>>n;
			rep(i,0,n-1){
     
				cin>>graph[i];
			}
			char a1=graph[1][0],a2=graph[0][1],b1=graph[n-2][n-1],b2=graph[n-1][n-2];
			if(a1!=a2){
     
				if(b1!=b2){
     
					cout<<2<<endl;
					if(a1==b1){
     
						cout<<"2 1"<<endl;
						cout<<n<<" "<<n-1<<endl;
					}
					else{
     
						cout<<"2 1"<<endl;
						cout<<n-1<<" "<<n<<endl;
					}
				}
				else{
     
					if(a1==b1){
     
						cout<<1<<endl;
						cout<<"2 1"<<endl;
					}
					else{
     
						cout<<1<<endl;
						cout<<"1 2"<<endl;
					}
				}
			}
			else{
     
				if(b1==b2){
     
					if(b1==a1){
     
						cout<<2<<endl;
						cout<<"1 2"<<endl;
						cout<<"2 1"<<endl;
					}
					else{
     
						cout<<0<<endl;
					}
					continue;
				}
				if(b1==a1){
     
					cout<<1<<endl;
					cout<<n-1<<" "<<n<<endl;
				}
				else{
     
					cout<<1<<endl;
					cout<<n<<" "<<n-1<<endl;
				}
			}
		}
	}
	return 0;
}

你可能感兴趣的:(#,CF,思维)