LeetCode#718-最长重复子数组-动态规划
package shuzu; /* 718. 最长重复子数组 给两个整数数组 A 和 B ,返回两个数组中公共的、长度最长的子数组的长度。 示例: 输入: A: [1,2,3,2,1] B: [3,2,1,4,7] 输出:3 解释: 长度最长的公共子数组是 [3, 2, 1] 。 提示: 1 <= len(A), len(B) <= 1000 0 <= A[i], B[i] < 100 解题思路: 动态规划 */ public class p718 { //动态规划 public int findLength(int[] A, int[] B) { int max = 0; int[][] dp = new int[A.length + 1][B.length + 1]; for (int i = 1; i <= A.length; i++) { for (int j = 1; j <= B.length; j++) { if (A[i - 1] == B[j - 1]) dp[i][j] = dp[i - 1][j - 1] + 1; else dp[i][j] = 0; max = Math.max(max, dp[i][j]); } } return max; } }
运行结果: