343. 整数拆分

给定一个正整数 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
cpp 复制代码
class Solution {
public:
    int integerBreak(int n) {
        // dp[i]: 拆分i,得到最大乘积为dp[i];
        // dp[i]:可以拆为dp[j] dp[i-j]
        //2、状态转移:dp[i] = max(j*(i-j),j*dp[i-j]);
        //分两种情况,拆为j 和 i-j
        //   1、i-j不能再拆了,那就是j*(i-j)
        //   2、i-j还能再拆,那就是j*dp[i-j]
        //也可以理解为 拆两个数 j*(i-j);拆三个即以上j * dp[i-j]; 
        //为什么不是dp[j]呢?我认为,再对j拆分,算是重复了,因为后面dp[i-j]已经拆过了,比方2*dp[4],上一个1*dp[5],对5拆分,可以得到1*1*2*2这个组合,也就是2*dp[4].所以不需要再对j拆分。
        vector<int>dp(n+1);
        dp[2] = 1;
        for(int i = 3;i <= n;i++){
            for(int j = 1;j < i;j++){ // j< i-1:j=i-1,在j = 1的时候dp[i-j]已经算过了
                //根据常识,数字越集中在一块,乘积越大,和越大。所以也可以j < n/2
                dp[i] = max(dp[i],max(j*(i-j),j*dp[i-j]));
            }
        }
        return dp[n];
    }
};
相关推荐
xvhao20134 分钟前
单源、多源最短路
数据结构·c++·算法·深度优先·动态规划·图论·图搜索算法
MATLAB代码顾问21 分钟前
多种群协同进化算法(MPCE)求解大规模作业车间调度问题——附MATLAB代码
开发语言·算法·matlab
FQNmxDG4S25 分钟前
JVM内存模型详解:堆、栈、方法区与垃圾回收
java·jvm·算法
We་ct44 分钟前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·leetcode·typescript·动态规划
AI科技星1 小时前
精细结构常数α作为SI 7大基本量纲统一耦合常数的量子几何涌现理论
算法·机器学习·数学建模·数据挖掘·量子计算
笑鸿的学习笔记1 小时前
qt-C++语法笔记之Qt Graphics View 框架中的类型辨析完全指南
c++·笔记·qt
山居秋暝LS1 小时前
安装C++版opencv和opencv_contrib
开发语言·c++·opencv
txzrxz2 小时前
动态规划——背包问题
算法·动态规划
Yingye Zhu(HPXXZYY)2 小时前
洛谷 P15553 [CCPC 2025 哈尔滨站] 液压机
算法
谭欣辰2 小时前
LCS(最长公共子序列)详解
开发语言·c++·算法