题意
题解
整数拆分有拆 2 2 2 次与拆多次的情况。 d p [ i ] dp[i] dp[i] 为 i i i 拆分得到的最大乘积,则有
d p [ i ] = m a x 1 ≤ j ≤ i − 1 { j ∗ ( i − j ) , j ∗ d p [ i − j ] } dp[i]=max_{1\leq j\leq i-1}\{j*(i-j),j*dp[i-j]\} dp[i]=max1≤j≤i−1{j∗(i−j),j∗dp[i−j]}
class Solution
{
#define maxn 60
public:
int dp[maxn];
int integerBreak(int n)
{
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];
}
};