记忆化搜索求助
查看原帖
记忆化搜索求助
114103
懵逼自动机楼主2020/6/7 23:41

代码如下

#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;
}

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

2020/6/7 23:41
加载中...