懵逼自动机 @ 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 好吧谢谢