leetcode 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

解析

dp[i]的定义:分拆数字i可以得到的最大乘积为dp[i]

dp[i]的最大乘积可以通过2种方式得到:

第一种(2个数相乘):

从1开始遍历j,

j*(i-j)---会被多次调用

第二种(多个数相乘)

j*dp[i-j]

dp[i-j]为重叠子问题,会被多次调用比如

复制代码
dp[5](dp[6-1],dp[7-2]...)

dp[7]为dp[2]*dp[5]与dp[3]*dp[4]等的最大值

代码

java 复制代码
import java.util.Scanner;

public class IntegerSplit {
    public static int integerBreak(int n) {
        int[] dp = new int[n+1];
        dp[2] = 1;
        for(int i = 3; i <= n; i++){
            for(int j = 1; j <= i; j++){
                dp[i] = Math.max(Math.max(j*(i-j), j*dp[i-j]),dp[i]);
            }
        }
        return dp[n];
    }

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        System.out.println(integerBreak(n));
    }
}

dp数组中的每一个元素都是经过一个不断扩大的循环计算出来的。

相关推荐
手写码匠1 分钟前
手写 AI 智能路由系统:从零构建多模型调度与负载均衡
人工智能·深度学习·算法·aigc
sheeta19981 分钟前
LeetCode 每日一题笔记 日期:2026.05.14 题目:2784. 检查数组是否是好的
笔记·算法·leetcode
故事还在继续吗2 分钟前
DPDK 教程(三):多队列 + RSS + 多 worker 的最小转发 / Echo
算法·哈希算法·dpdk
AI科技星4 分钟前
全域数学·体积与表面积通项定理【乖乖数学】
人工智能·算法·数学建模·数据挖掘·机器人
Yingjun Mo9 分钟前
1. 在线学习引言
学习·算法
李日灐12 分钟前
< 12 > Linux进程:进程虚拟地址空间机制 —— 内存管理的美学
linux·运维·算法
Mr_pyx21 分钟前
LeetCode 226. 翻转二叉树(多种解法详解)
算法·深度优先
qeen8721 分钟前
【算法笔记】各种常见排序算法详细解析(上)
c语言·数据结构·c++·学习·算法·排序算法
绿蕉23 分钟前
自动驾驶技术的演进之路:从规则算法到端到端架构
算法·架构·自动驾驶
Ulyanov24 分钟前
《从质点到位姿:基于Python与PyVista的导弹制导控制全栈仿真》: 基石——3-DOF质点弹道的高保真建模与数值稳定性分析
开发语言·python·算法·ui·系统仿真