343. 整数拆分

  1. 整数拆分
    给定一个正整数 n ,将其拆分为 k 个 正整数 的和( k >= 2 ),并使这些整数的乘积最大化。

返回 你可以获得的最大乘积 。

示例 1:

输入: n = 2
输出: 1
解释: 2 = 1 + 1, 1 × 1 = 1。
示例 2:

输入: n = 10
输出: 36
解释: 10 = 3 + 3 + 4, 3 × 3 × 4 = 36。

提示:

2 <= n <= 58

// 题目使用动态规划进行解决
// 1、确定dp数组的含义
// dp[i] 表示i进行拆分以后,乘积最大化的结果
// 2、找出递推公式
// 要按照把一个数拆分成多少个数来进行分析
// 题目中规定,至少拆分成两个
// 那么分情况进行讨论
// 如果拆分成2个数,其中一个数为j,那么另外一个数就是n - j, 所得到的乘积就是 j*(n-j)
// 如果拆封成2个以上的数,其中一个数为j,那么剩下的数组成的最大拆分以后的乘积就是dp[n - j], 那么所得到的乘积就是j * dp[n - j]
// 所以最后的结果就是将上面j的所有可能对应的数的最大值就是dp[n]
// 因此,递推公式就是 dp[n] = max{dp[n], j*(n - j), j*dp[n-j]}
// 3、dp数组初始化
// 按照题意,我目前可以看出来
// dp[0] = 0
// dp[1] = 1
// dp[2] = 1
// 4、确定dp数组计算顺序,dp数组是一维数组,那么就是按照从2到n进行计算即可
// 5、获取结果
// 根据题意和dp数组含义,即可得到最后的结果就是dp[n]
// 6、 进行举例验证
// n = 10
// 0 1 1 2 4 6 9 12 18 27 36

int max1(int a, int b, int c)
{
    if (a >= b && a >= c) return a;
    if (b >= a && b >= c) return b;
    if (c >= a && c >= b) return c;
    return 0;
}



int integerBreak(int n){

    if (n == 0) return 0;
    if (n == 1) return 1;

    int*dp = (int*)malloc(sizeof(int) * (n + 1));
    memset(dp, 0x00, sizeof(int) * (n + 1));
    dp[0] = 0;
    dp[1] = 1;
    dp[2] = 1;

    int i, j;
    for (i = 3; i < n + 1; i++) {
        for (j = 1; j < i; j++) {
            dp[i] = max1(dp[i], j * (i - j), j * dp[i - j]);
        }
    }

    int ans = dp[n];
    free(dp);
    dp = NULL;
    return ans;


}

你可能感兴趣的:(leetcode,动态规划,算法)