Leetcode 343. 整数拆分 动态规划

原题链接:Leetcode 343. 整数拆分

cpp 复制代码
class Solution {
public:
    int integerBreak(int n) {
        if(n==2) return 1;
        int res=0;
        // dp[i]表示i拆分后可以获得的最大乘积
        vector<int> dp(n+1,0);
        dp[2]=1;
        for(int i=3;i<=n;i++){
            for(int j=1;j<=i/2;j++){
                // 将 i 拆分成 j 和 i−j 的和,且 i−j 不再拆分成多个正整数,此时的乘积是 j×(i−j)
                // 将 i 拆分成 j 和 i−j 的和,且 i−j 继续拆分成多个正整数,此时的乘积是 j×dp[i−j]
                dp[i]=max(dp[i],max((i-j)*j , dp[i-j]*j));
            }
        }
        return dp[n];
    }
};
相关推荐
小宇的天下17 分钟前
Calibre LVS Circuit Comparison(2)
算法·lvs
迈巴赫车主43 分钟前
求最大公约数-欧几里得算法(辗转相除法)
算法·最大公约数
lxl13071 小时前
C++算法(15)BFS_FloodFill
算法·宽度优先
小王C语言1 小时前
【基础IO】————简单设计一下libc库
前端·数据结构·算法
亦复何言??1 小时前
BeyondMimic 论文解析
人工智能·算法·机器人
WolfGang0073211 小时前
代码随想录算法训练营 Day20 | 回溯算法 part02
算法
YXXY3131 小时前
前缀和算法
算法
客卿1231 小时前
滑动窗口--模板
java·算法
_日拱一卒1 小时前
LeetCode:滑动窗口的最大值
数据结构·算法·leetcode
codeの诱惑2 小时前
推荐算法(一):数学基础回顾——勾股定理与欧氏距离
算法·机器学习·推荐算法