#include<stdio.h>
#include<iostream>
#include<string.h>
#include<string>
#include<ctype.h>
#include<math.h>
#include<set>
#include<map>
#include<vector>
#include<queue>
#include<bitset>
#include<algorithm>
#include<time.h>
using namespace std;
void fre() { freopen("c://test//input.in", "r", stdin); freopen("c://test//output.out", "w", stdout); }
#define MS(x,y) memset(x,y,sizeof(x))
#define MC(x,y) memcpy(x,y,sizeof(x))
#define MP(x,y) make_pair(x,y)
#define ls o<<1
#define rs o<<1|1
typedef long long LL;
typedef unsigned long long UL;
typedef unsigned int UI;
template <class T1, class T2>inline void gmax(T1 &a, T2 b) { if (b>a)a = b; }
template <class T1, class T2>inline void gmin(T1 &a, T2 b) { if (b<a)a = b; }
const int N = 105, M = 0, Z = 1e9 + 7, ms63 = 0x3f3f3f3f;
int n;
char a[N][N];
bool solve()
{
for (int i = 1; i <= n; ++i)
{
for (int j = 1; j <= n; ++j)//if (a[i][j] == 'o')
{
int ans = 0;
if (a[i][j + 1] == 'o')++ans;
if (a[i + 1][j] == 'o')++ans;
if (a[i][j - 1] == 'o')++ans;
if (a[i - 1][j] == 'o')++ans;
if (ans & 1)return 0;
}
}
return 1;
}
int main()
{
while (~scanf("%d", &n))
{
for (int i = 1; i <= n; ++i)scanf("%s", a[i] + 1);
puts(!solve() ? "NO" : "YES");
}
return 0;
}
/*
【trick&&吐槽】
妈的智障,读题要好好读>_<
【题意】
给你一个n*n的棋盘。棋盘上不是x就是o。
让你判断,是否对于每个点,相邻的o的个数都为偶数个
【类型】
水题
*/
【Codeforces Round 263 (Div 2)A】【水题 认真读题】Appleman and Easy Task 每个点的相邻o是否都为偶数
最新推荐文章于 2019-10-17 10:06:53 发布