记忆化搜索求助

P1434 [SHOI2002] 滑雪

懵逼自动机 @ 2020-06-07 23:41:59

代码如下

#include <bits/stdc++.h>
using namespace std;
int h[105][105],dp[105][105],r,c,ans,vis[105][105];
int dx[4]={0,0,-1,1},dy[4]={1,-1,0,0};
void dfs(int x,int y)
{
    vis[x][y]=1;
    for(int i=0;i<4;i++){
        int x1=x+dx[i],y1=y+dy[i];
        if(vis[x1][y1]==0)
            dfs(x1,y1);
        if(h[x1][y1]<h[x][y])
            dp[x][y]=max(dp[x][y],dp[x1][y1]+1);
    }
    return;
}
int main()
{
    memset(h,0x3f,sizeof(h));
    memset(vis,-1,sizeof(vis));
    scanf("%d%d",&r,&c);
    for(int i=1;i<=r;i++){
        for(int j=1;j<=c;j++){
            scanf("%d",&h[i][j]);
            vis[i][j]=0;
            dp[i][j]=1;
        }
    }
    dfs(1,1);
    printf("%d",ans);
    return 0;
}

查了很久才发现是用上一个点的值更新下一个点的时候会出错,想知道有没有只搜索一遍的方法(因为树做多了,,)


by pocafup @ 2020-06-08 02:41:27

只做一遍窝只能想到用pq搜(

dfs貌似没法一遍。


by Dimly_dust @ 2020-06-08 06:51:58

此题DP+记忆化。。。


by 懵逼自动机 @ 2020-06-08 12:23:06

@pocafup 好吧谢谢


|