#include<bits/stdc++.h>
using namespace std;
#define N 10
char s[N][N];
int dx[4]={1,-1,0,0};
int dy[4]={0,0,1,-1};
int n,str[N][N],ans=0;
void bfs(int x,int y,int l,int r){
if(l>0&&l==r){
ans=max(ans,l+r);
return ;
}
for(int i=0;i<4;i++){
int xx=x+dx[i],yy=y+dy[i];
if(xx<1||yy<1||xx>n||yy>n||str[xx][yy]==1) continue;
if(r>0&&s[xx][yy]=='(') continue;
str[xx][yy]=1;
if(s[xx][yy]=='(') bfs(xx,yy,l+1,r);
else bfs(xx,yy,l,r+1);
str[xx][yy]=0;
}
}
int main(){
cin>>n;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
cin>>s[i][j];
if(s[1][1]==')'){
cout<<"0";
return 0;
}
str[1][1]=1;
bfs(1,1,1,0);
cout<<ans<<endl;
return 0;
}
AcWing 2005. 马蹄铁
最新推荐文章于 2024-10-31 19:07:52 发布