代码随想录第40天|343. 整数拆分

2024-04-19 04:36

本文主要是介绍代码随想录第40天|343. 整数拆分,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

343. 整数拆分 

343. 整数拆分 - 力扣(LeetCode)

代码随想录 (programmercarl.com)

动态规划,本题关键在于理解递推公式!| LeetCode:343. 整数拆分_哔哩哔哩_bilibili

给定一个正整数 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数组以及下标的含义:分拆数字i可以得到的最大乘积为dp[i];

2、确定递推公式:dp[i] 的最大值怎么得到?j*(i-j) 或者 j*dp[i-j];

3、dp的初始化:dp[2]=1;

4、确定遍历顺序:

  // 从正整数 3 开始遍历到 nfor (int i = 3; i <= n; i++) {// 内层循环变量 j 表示拆分的位置,从 1 开始遍历到 i-j,因为 j 最大不会超过 i 的一半for (int j = 1; j <= i - j; j++) {// 计算将正整数 i 拆分为 j 和 i-j 后的乘积,取两者中的较大值// Math.max(j * (i - j), j * dp[i - j]) 表示将正整数 i 拆分成两个数和两个以上的数的情况下的最大乘积dp[i] = Math.max(dp[i], Math.max(j * (i - j), j * dp[i - j]));}}

5、举例推导dp公式:当n=10:

综合代码:

class Solution {public int integerBreak(int n) {// 创建一个数组 dp,其中 dp[i] 表示将正整数 i 拆分后的结果的最大乘积int[] dp = new int[n + 1];// 初始化 dp[2],因为题目要求至少拆分成两个正整数,所以 dp[2] 的最大乘积为 1dp[2] = 1;// 从正整数 3 开始遍历到 nfor (int i = 3; i <= n; i++) {// 内层循环变量 j 表示拆分的位置,从 1 开始遍历到 i-j,因为 j 最大不会超过 i 的一半for (int j = 1; j <= i - j; j++) {// 计算将正整数 i 拆分为 j 和 i-j 后的乘积,取两者中的较大值// Math.max(j * (i - j), j * dp[i - j]) 表示将正整数 i 拆分成两个数和两个以上的数的情况下的最大乘积dp[i] = Math.max(dp[i], Math.max(j * (i - j), j * dp[i - j]));}}// 返回将正整数 n 拆分后的结果的最大乘积return dp[n];}
}

这篇关于代码随想录第40天|343. 整数拆分的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/916641

相关文章

Python中顺序结构和循环结构示例代码

《Python中顺序结构和循环结构示例代码》:本文主要介绍Python中的条件语句和循环语句,条件语句用于根据条件执行不同的代码块,循环语句用于重复执行一段代码,文章还详细说明了range函数的使... 目录一、条件语句(1)条件语句的定义(2)条件语句的语法(a)单分支 if(b)双分支 if-else(

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

nginx-rtmp-module模块实现视频点播的示例代码

《nginx-rtmp-module模块实现视频点播的示例代码》本文主要介绍了nginx-rtmp-module模块实现视频点播,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录预置条件Nginx点播基本配置点播远程文件指定多个播放位置参考预置条件配置点播服务器 192.

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

深入解析Spring TransactionTemplate 高级用法(示例代码)

《深入解析SpringTransactionTemplate高级用法(示例代码)》TransactionTemplate是Spring框架中一个强大的工具,它允许开发者以编程方式控制事务,通过... 目录1. TransactionTemplate 的核心概念2. 核心接口和类3. TransactionT

Java实现Elasticsearch查询当前索引全部数据的完整代码

《Java实现Elasticsearch查询当前索引全部数据的完整代码》:本文主要介绍如何在Java中实现查询Elasticsearch索引中指定条件下的全部数据,通过设置滚动查询参数(scrol... 目录需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后需求背景通常情况下

Git提交代码详细流程及问题总结

《Git提交代码详细流程及问题总结》:本文主要介绍Git的三大分区,分别是工作区、暂存区和版本库,并详细描述了提交、推送、拉取代码和合并分支的流程,文中通过代码介绍的非常详解,需要的朋友可以参考下... 目录1.git 三大分区2.Git提交、推送、拉取代码、合并分支详细流程3.问题总结4.git push