#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <cstdlib>
#define N 105
using namespace std;
char s[N];
int snow[N][N], dp[N][N];
int dir[4][2] = {{1, 0}, {0, 1}, {-1, 0}, {0, -1}};
int n, m, Max;
int DFS(int x, int y) {
    int px, py, ans = 1, t;
    if (dp[x][y] != -1) return dp[x][y];
    for (int i = 0; i < 4; i++) {
        px = x + dir[i][0];
        py = y + dir[i][1];
        if (px < 0 || py < 0) continue;
        if (px >= n || py >= m) continue;
        if (snow[px][py] < snow[x][y]) {
            t = DFS(px, py);    
            if (t + 1 > ans) ans = t + 1;
        }
    }   
    return dp[x][y] = ans;
}
int main() {
    int T;
    scanf("%d", &T);
    while (T--) {
        memset(dp, -1, sizeof(dp));
        Max = 0;
        scanf("%s", s);
        scanf("%d %d", &n, &m);
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                scanf("%d", &snow[i][j]);
            }
        }
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < m; j++) {
                int temp = DFS(i, j);   
                if (temp > Max) {
                    Max = temp;
                }
            }
        }
        printf("%s: %d\n", s, Max);
    }
    return 0;
}
uva 10285 Longest Run on a Snowboard (记忆化搜索)
原文:http://blog.csdn.net/llx523113241/article/details/44519381