當前位置:
首頁 >
【记忆化搜索】bzoj3208 花神的秒题计划Ⅰ
發布時間:2023/12/19
28
豆豆
生活随笔
收集整理的這篇文章主要介紹了
【记忆化搜索】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\n",ans);}}return 0; }轉載于:https://www.cnblogs.com/autsky-jadek/p/4370201.html
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的【记忆化搜索】bzoj3208 花神的秒题计划Ⅰ的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 消息队列服务器 轻量,PHP的轻量消息队
- 下一篇: 服务器mtf路径文件损坏,来自节点 js