Java中等题-整数拆分(力扣)

给定一个正整数 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。

这道题我没有思路,看了官方解题思路之后,梳理如下:

用一个数组dp[i]表示i能被拆分出的乘积最大的整数,

一个数n,可以被拆为j和n-j, n-j可以选择不拆开和拆开

n=Math.max(j*(n-j),j*dp[n-j]);

j的范围在1~n-1

java 复制代码
class Solution {
    public int integerBreak(int n) {

        if(n<2){
            return 0;
        }
        int dp[]=new int[n+1];
        dp[0]=0;
        dp[1]=0;

       for(int i=2;i<n+1;i++){
           for(int j=1;j<i;j++){
               dp[i]=Math.max(dp[i],Math.max((i-j)*j,j*dp[i-j]));
           }
       }
       return dp[n];

    }
}
相关推荐
Re.不晚几秒前
Java入门15——抽象类
java·开发语言·学习·算法·intellij-idea
雷神乐乐6 分钟前
Maven学习——创建Maven的Java和Web工程,并运行在Tomcat上
java·maven
码农派大星。9 分钟前
Spring Boot 配置文件
java·spring boot·后端
顾北川_野17 分钟前
Android 手机设备的OEM-unlock解锁 和 adb push文件
android·java
江深竹静,一苇以航19 分钟前
springboot3项目整合Mybatis-plus启动项目报错:Invalid bean definition with name ‘xxxMapper‘
java·spring boot
confiself35 分钟前
大模型系列——LLAMA-O1 复刻代码解读
java·开发语言
Wlq041540 分钟前
J2EE平台
java·java-ee
XiaoLeisj1 小时前
【JavaEE初阶 — 多线程】Thread类的方法&线程生命周期
java·开发语言·java-ee
为什么这亚子1 小时前
九、Go语言快速入门之map
运维·开发语言·后端·算法·云原生·golang·云计算
豪宇刘1 小时前
SpringBoot+Shiro权限管理
java·spring boot·spring