标签:
Description
1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9
Input
Output
Sample Input
5 5 1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9
Sample Output
25
很经典的记忆化搜索
由于要多次搜索 而且搜索的又是重复的路径 为了避免超时 所以使用一个数组存贮结果 当搜索到已经搜索到的位置 返回结果
#include <stdio.h>
#include <algorithm>
#include <string.h>
using namespace std;
int n,m;
int map[105][105];
int dp[105][105];
bool vis[105][105];
int dir[4][2]={1,0,-1,0,0,1,0,-1};
bool limit(int x,int y)
{
if(x<0||y<0||x==n||y==m||vis[x][y])
return false;
return true;
}
int dfs(int x,int y)
{
if(dp[x][y]) return dp[x][y];
for(int i=0;i<4;i++)
{
int xx=x+dir[i][0];
int yy=y+dir[i][1];
if(limit(xx,yy)&&map[x][y]>map[xx][yy])
{
int temp=dfs(xx,yy);
if(dp[x][y]<temp+1)
dp[x][y]=temp+1;
}
}
return dp[x][y];
}
int main()
{
while(~scanf("%d %d",&n,&m))
{
memset(dp,0,sizeof(dp));
memset(map,0,sizeof(map));
for(int i=0;i<n;i++)
for(int j=0;j<m;j++)
scanf("%d",&map[i][j]);
int result=0;
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
memset(vis,0,sizeof(vis));
vis[i][j]=true;
result=max(result,dfs(i,j));
}
}
printf("%d\n",result+1);
}
return 0;
} 标签:
原文地址:http://blog.csdn.net/su20145104009/article/details/51372299