hdu 1078 FatMouse and Cheese 记忆化搜索

简介:

  一开始打算正向用状态dp,结果果断超时,换成反向记忆话搜索就过了


/*
author:jxy
lang:C/C++
university:China,Xidian University
**If you need to reprint,please indicate the source**
*/
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <queue>
#define INF 1E9
using namespace std;
int map[105][105];
int n,k;
int dp[105][105];
int dir[4][2]={1,0,-1,0,0,1,0,-1};
int ans;
int walk(int x,int y)
{
    if(dp[x][y])return dp[x][y];
    int i,j;
    int nx,ny,t=0;
    for(i=0;i<4;i++)
    {
      nx=x;ny=y;
      for(j=0;j<k;j++)
      {
        nx+=dir[i][0];ny+=dir[i][1];
        if(nx<=0||ny<=0||nx>n||ny>n)break;
        if(map[nx][ny]>map[x][y])
            t=max(t,walk(nx,ny));
      }
    }
    dp[x][y]=t+map[x][y];
    return dp[x][y];
}
int main()
{
    while(~scanf("%d%d",&n,&k)&&n+1)
    {
        memset(map,-1,sizeof(map));
        memset(dp,0,sizeof(dp));
        int i,j;
        for(i=1;i<=n;i++)
            for(j=1;j<=n;j++)
            {
               scanf("%d",&map[i][j]);
            }
        printf("%d\n",walk(1,1));
    }
}


目录
相关文章
|
7月前
hdu1406 完数 (水题)
hdu1406 完数 (水题)
33 0
|
人工智能 vr&ar Perl
codeforces1509 C. The Sports Festival (区间DP)
codeforces1509 C. The Sports Festival (区间DP)
94 0
HDU-1009,FatMouse' Trade(贪心水题)
HDU-1009,FatMouse' Trade(贪心水题)
|
算法
HDOJ/HDU 1015 Safecracker(深搜)
HDOJ/HDU 1015 Safecracker(深搜)
83 0
HDOJ/HDU 2551 竹青遍野(打表~)
HDOJ/HDU 2551 竹青遍野(打表~)
95 0
|
C++ 人工智能 BI
HDU2032杨辉三角
有点强迫症,主函数必须简洁,但是这里的if判断语句很碍眼,自己也并没有想到什么不画蛇添足的方法使代码更加简洁......
1485 0
|
人工智能 BI 存储
|
并行计算 算法 Java
HDU 1874 畅通工程续【Floyd算法实现】
畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 53806    Accepted Submission(s): 20092 Problem Description 某省自从实行了很多年的畅通工程计划后,终于修建了很多路。
1071 0