Fox Ciel has a board with n rows and n columns. So, the board consists of n × n cells. Each cell contains either a symbol '.', or a symbol '#'.
A cross on the board is a connected set of exactly five cells of the board that looks like a cross. The picture below shows how it looks.
![](https://i-blog.csdnimg.cn/blog_migrate/6c3a699ae08f4968d011f4cc9af04f5d.png)
Ciel wants to draw several (may be zero) crosses on the board. Each cross must cover exactly five cells with symbols '#', and any cell with symbol '#' must belong to some cross. No two crosses can share a cell.
Please, tell Ciel if she can draw the crosses in the described way.
The first line contains an integer n (3 ≤ n ≤ 100) — the size of the board.
Each of the next n lines describes one row of the board. The i-th line describes the i-th row of the board and consists of n characters. Each character is either a symbol '.', or a symbol '#'.
Output a single line with "YES" if Ciel can draw the crosses in the described way. Otherwise output a single line with "NO".
5 .#... ####. .#### ...#. .....
YES
4 #### #### #### ####
NO
6 .#.... ####.. .####. .#.##. ###### .#..#.
YES
6 .#..#. ###### .####. .####. ###### .#..#.
NO
3 ... ... ...
YES
In example 1, you can draw two crosses. The picture below shows what they look like.
![](https://i-blog.csdnimg.cn/blog_migrate/30535671e26855e16dd3b192f4a4ea60.png)
In example 2, the board contains 16 cells with '#', but each cross contains 5. Since 16 is not a multiple of 5, so it's impossible to cover all.
题目链接:http://codeforces.com/problemset/problem/389/B
题目大意:问是否所有的#都被用上做十字图案,不能重复使用;
思路:只搜索十字最上面那个#,吧用过的#标记一下就行了,注意边界
代码:
#include <iostream>
#include <string.h>
using namespace std;
int main()
{
int vis[110][110];
char a[110][110];
int n;
while(cin>>n)
{
memset(vis,0,sizeof(vis));
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
cin>>a[i][j];
}
}
int flag=0;
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
if(a[i][j]=='#'&&!vis[i][j])
{
if(i>=n-2||j==0||j==n-1)
{
flag=1;
break;
}
else if(a[i+1][j]=='#'&&!vis[i+1][j]&&a[i+2][j]=='#'&&!vis[i+2][j]&&a[i+1][j-1]=='#'&&!vis[i+1][j-1]&&a[i+1][j+1]=='#'&&!vis[i+1][j+1])
{
vis[i][j]=1;
vis[i+1][j]=1;
vis[i+1][j-1]=1;
vis[i+1][j+1]=1;
vis[i+2][j]=1;
}
else
{
flag=1;
break;
}
}
}if(flag) break;
}if(flag) cout<<"NO"<<endl;
if(!flag) cout<<"YES"<<endl;
}
return 0;
}