zoukankan      html  css  js  c++  java
  • 【记忆化搜索】bzoj3208 花神的秒题计划Ⅰ

    暴力

    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    #define N 701
    const int dx[]={0,0,-1,1},dy[]={-1,1,0,0};
    int n,mem[N][N],a[N][N],m;
    bool cant[N][N];
    int f(int x,int y)
    {
    	if(mem[x][y]) return mem[x][y];
    	mem[x][y]=1;
    	for(int i=0;i<4;++i)
    	  if(x+dx[i]>0&&x+dx[i]<=n&&y+dy[i]>0&&y+dy[i]<=n&&(!cant[x+dx[i]][y+dy[i]])&&a[x][y]>a[x+dx[i]][y+dy[i]])
    	    mem[x][y]=max(mem[x][y],f(x+dx[i],y+dy[i])+1);
    	return mem[x][y];
    }
    int main()
    {
    	int A,B,C,D; char op[2];
    	scanf("%d",&n);
    	for(int i=1;i<=n;++i)
    	  for(int j=1;j<=n;++j)
    	    scanf("%d",&a[i][j]);
    	scanf("%d",&m);
    	for(;m;--m)
    	  {
    	  	scanf("%s",op);
    	  	if(op[0]=='C')
    	  	  {
    	  	  	scanf("%d%d%d",&A,&B,&C);
    	  	  	a[A][B]=C;
    	  	  }
    	  	else if(op[0]=='S')
    	  	  {
    	  	  	scanf("%d%d%d%d",&A,&B,&C,&D);
    	  	  	for(int i=A;i<=C;++i)
    	  	  	  for(int j=B;j<=D;++j)
    	  	  	    cant[i][j]=1;
    	  	  }
    	  	else if(op[0]=='B')
    	  	  {
    	  	  	scanf("%d%d%d%d",&A,&B,&C,&D);
    	  	  	for(int i=A;i<=C;++i)
    	  	  	  for(int j=B;j<=D;++j)
    	  	  	    cant[i][j]=0;
    	  	  }
    	  	else
    	  	  {
    	  	  	int ans=1;
    	  	  	memset(mem,0,sizeof(mem));
    	  	  	for(int i=1;i<=n;++i)
    	  	  	  for(int j=1;j<=n;++j)
    	  	  	    if(!cant[i][j])
    	  	  	      ans=max(ans,f(i,j));
    	  	  	printf("%d
    ",ans);
    	  	  }
    	  }
    	return 0;
    }
  • 相关阅读:
    array与xml转换实现(转)
    设计模式之: 策略模式
    设计模式之: 代理模式
    设计模式之: 状态模式
    dedecms分页
    dedecms导出csv文件
    假如项目中使用到了多 表查询,怎么办?
    git忽略某个文件夹
    git忽略某个文件
    无极限分类
  • 原文地址:https://www.cnblogs.com/autsky-jadek/p/4370201.html
Copyright © 2011-2022 走看看