java
复制代码
class Solution {
int row;
int col;
int[][] directions;
public int longestIncreasingPath(int[][] matrix) {
int res = 0;
row = matrix.length;
col = matrix[0].length;
directions = new int[][] {{-1, 0}, {1, 0}, {0, -1}, {0, 1}};
int[][] dp = new int[row][col];
for (int i = 0; i < row; i++) {
for (int j = 0; j < col; j++) {
res = Math.max(res, findMaxPath(matrix, dp, i, j));
}
}
return res;
}
public int findMaxPath(int[][] matrix, int[][] dp, int i, int j) {
if (dp[i][j] != 0) {
return dp[i][j];
}
int maxPath = 0;
for (int[] direction : directions) {
int x = i + direction[0];
int y = j + direction[1];
if (x < 0 || x >= row || y < 0 || y >= col) {
continue;
}
if (matrix[x][y] <= matrix[i][j]) {
continue;
}
maxPath = Math.max(maxPath, findMaxPath(matrix, dp, x, y));
}
dp[i][j] = maxPath + 1;
return dp[i][j];
}
}