我一直在这个问题上一段时间,无法拿出解决方案的最长递增序列;我希望你能帮上忙..
我试图找到最长的增加序列的数字。例如,如果我有以下4X4阵列:
[![enter image description here][1]][1]
int [] nums = {
{97 , 47 , 56 , 36},
{35 , 57 , 41 , 13},
{89 , 36 , 98 , 75},
{25 , 45 , 26 , 17}
};
预期的结果:返回8和LIS 17,26,36,41,47,56,57,97 我没有答案到了它,我试图达到它。
17 (3,3)
26 (3,2)
36 (2,1)
41 (1,2)
47 (0,1)
56 (0,2)
57 (1,1)
97 (0,0)
我希望我的例子是很清楚..
这是我的代码;当我试图找到最长的增长路径时,它不会向后对角地进行。任何人都可以帮助我吗?
public class Solution2 {
static int[] dx = { 1, -1, 0, 0 };
static int[] dy = { 0, 0, 1, -1 };
public static int longestIncreasingPath(int[][] matrix) {
if (matrix.length == 0)
return 0;
int m = matrix.length, n = matrix[0].length;
int[][] dis = new int[m][n];
int ans = 0;
for (int i = 0; i < m; i++) {
for (int j = 0; j < n; j++) {
ans = Math.max(ans, dfs(i, j, m, n, matrix, dis));
}
}
return ans;
}
static int dfs(int x, int y, int m, int n, int[][] matrix, int[][] dis) {
if (dis[x][y] != 0)
return dis[x][y];
for (int i = 0; i < 4; i++) {
int nx = x + dx[i];
int ny = y + dy[i];
if (nx >= 0 && ny >= 0 && nx < m && ny < n && matrix[nx][ny] > matrix[x][y]) {
dis[x][y] = Math.max(dis[x][y], dfs(nx, ny, m, n, matrix, dis));
}
}
return ++dis[x][y];
}
public static void main(String[] args) {
int arr[][] = {
{ 97, 47, 56, 36 },
{ 35, 57, 41, 13 },
{ 89, 36, 98, 75 },
{ 25, 45, 26, 17 }
};
System.out.println(longestIncreasingPath(arr));
}
}
我不明白你正在尝试做的。您列出了不在您提供的数组中的最长序列;我甚至没有看到你的答案和你的数据之间的关系。这个最长的序列从哪里来? –
你的例子不清楚它将如何返回8? – Lokesh
17-> 26-> 36-> 41-> 47-> 56-> 57-> 97 它从阵列的右下方往上走。 我在示例中添加了坐标。 –