>  기사  >  Java  >  LeetCode 반복 하위 배열의 최대 길이

LeetCode 반복 하위 배열의 최대 길이

坏嘻嘻
坏嘻嘻원래의
2018-09-14 13:49:341802검색

이번 글에서는 LeetCode의 반복 하위 배열의 최대 길이에 대해 소개합니다.

두 개의 정수 배열이 주어지면 A 和 B 두 배열의 공통 부분 배열과 가장 긴 부분 배열의 길이를 반환합니다.

예 1:

输入:A: [1,2,3,2,1]
B: [3,2,1,4,7]输出: 3解释: 长度最长的公共子数组是 [3, 2, 1]。

설명:

  1. 1 <= len(A), len(B) <= 1000

  2. 0 <= A[i], B [i] < 10

솔루션은 다음과 같은 고전적인 동적 프로그래밍 알고리즘입니다.

public class MaxLengthRepeatedSubarray {
    //动态规划算法
    public static int findLength(int[] A, int[] B) {
        int aSize = A.length;
        int bSize = B.length;
        int[][] dp = new int[aSize + 1][bSize + 1];
        int result = 0;
        for (int i = 1; i < dp.length; i++) {
            for (int j = 1; j < dp[i].length; j++) {
                dp[i][j] = A[i - 1] == B[j - 1] ? dp[i - 1][j - 1] + 1 : 0;
                result = Math.max(result, dp[i][j]);
            }
        }
        return result;
    }

    public static void main(String[] args) {
        int[] a = new int[]{1, 2, 3, 2, 1};
        int[] b = new int[]{3, 2, 1, 4, 7};
        System.out.println(findLength(a, b));
    }
}

관련 권장 사항:

LeetCode 2 역 폴란드어 표기법 평가

python 목록 목록을 사용하여 행렬 표시 질문?

위 내용은 LeetCode 반복 하위 배열의 최대 길이의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.