343. Integer Break

Given a positive integern, break it into the sum ofat leasttwo positive integers and maximize the product of those integers. Return the maximum product you can get.

For example, givenn= 2, return 1 (2 = 1 + 1); givenn= 10, return 36 (10 = 3 + 3 + 4).

Note: You may assume thatnis not less than 2 and not larger than 58.

class Solution {
    public int integerBreak(int n) {
        int[] dp = new int[n + 1];

        dp[0] = dp[1] = 1;
        for (int i = 2; i <= n; i++){
            dp[i] = 1;
            for (int j = 1; j < i; j++){
                dp[i] = Math.max(dp[i], Math.max(dp[j], j) * (i - j));
            }
        }

        return dp[n];
    }
}

results for ""

    No results matching ""