这题看完数据范围一脸的暴力和不信….
直接上记忆化搜索了…
code:
#include<set>
#include<map>
#include<deque>
#include<queue>
#include<stack>
#include<cmath>
#include<ctime>
#include<bitset>
#include<string>
#include<vector>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<climits>
#include<complex>
#include<iostream>
#include<algorithm>
#define ll long long
#define inf 1e9
using namespace std;
const int maxn = 710;
const int dx[4]={-1,0,1,0};
const int dy[4]={0,1,0,-1};
int n,m;
int f[maxn][maxn],v[maxn][maxn];
bool vis[maxn][maxn],c[maxn][maxn];
void up(int &x,int y){if(y>x)x=y;}
void dfs(int x,int y)
{
vis[x][y]=true;
f[x][y]=1; int val=v[x][y];
for(int k=0;k<4;k++)
{
int tx=x+dx[k],ty=y+dy[k];
if(tx&&ty&&tx<=n&&ty<=n&&c[tx][ty])
{
if(v[tx][ty]>val) { if(!vis[tx][ty]) dfs(tx,ty); up(f[x][y],f[tx][ty]+1); }
}
}
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
scanf("%d",&v[i][j]);
memset(c,true,sizeof c);
scanf("%d",&m);
while(m--)
{
char s[100]; scanf("%s",s);
if(s[0]=='C')
{
int x1,y1,val; scanf("%d%d%d",&x1,&y1,&val);
v[x1][y1]=val;
}
else if(s[0]=='S')
{
int x1,y1,x2,y2; scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
for(int i=x1;i<=x2;i++)
for(int j=y1;j<=y2;j++)
c[i][j]=false;
}
else if(s[0]=='B')
{
int x1,y1,x2,y2; scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
for(int i=x1;i<=x2;i++)
for(int j=y1;j<=y2;j++)
c[i][j]=true;
}
else if(s[0]=='Q')
{
int ret=0;
memset(vis,false,sizeof vis);
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
if(c[i][j])
{
if(!vis[i][j]) dfs(i,j);
up(ret,f[i][j]);
}
}
}
printf("%d\n",ret);
}
}
return 0;
}