Skip to content

Latest commit

 

History

History
24 lines (24 loc) · 630 Bytes

File metadata and controls

24 lines (24 loc) · 630 Bytes

整数拆分

思路

  • 动态规划,dp[i]表示i所可以得到的最大乘积
  • dp[i] = max(dp[i],max(j*(i-j), j*dp[i-j]));

代码

  class Solution {
public:
    int integerBreak(int n) {
        if(n<2||n>58) return 0;
        // dp[i]表示i可以获得的最大乘积
        vector<int> dp(n+1,0);
        dp[1] = 0;
        dp[2] = 1;
        for(int i = 3; i <= n; i++){
            for(int j = 1; j < i; j++){
                dp[i] = max(dp[i],max(j*(i-j),j*dp[i-j]));
            }
        }
        return dp[n];
    }
};