关于动态规划【力扣343.整数拆分的递推公式怎么理解?】

目录

一、先明确这里面的参数分别是什么意思

二、再明确各个参数的取值范围

三、再理解递推公式


一、先明确这里面的参数分别是什么意思

1、i表示"当前正在拆分整数i"

2、当i=n时,表示"当前正在拆分整数n"

3、j表示"在拆分整数i的时候,以哪一个数为第一个拆分出来的数"

4、dpi表示"拆分整数i得到的最大乘积"

二、再明确各个参数的取值范围

1、i从3开始,题目已经说明,n>=2。n=2时可以直接初始化

2、j从1开始,因为第一个拆出来的数如果是0的话,就没有意义了,0乘任何数都等于0,不会是最大的乘积。所以j从1开始。

3、第一层for循环里i<=n。因为最后要求到dpn

4、第二层for循环里j<=i/2。因为这道题最关键的是要靠近每个加数平均一点(比如:10可以 = 3+3+4,这里每个加数3、3、4就差不多是一样的,平均都是3;乘积为36。10可以=5+5,这里每个加数5、5就差不多是一样的,平均都是5;乘积为25)如果再往后一点,就更难取到乘积是最大的情况了。所以第一个拆出来的数不用考虑被拆的一半以上了(比如:如果把第一个拆出来的数大于当前被拆的数的一半以上,也就是比如把10拆成6+4,这里的j就是6,乘积是24;把10拆成7+3,这里的j就是7,乘积是21;把10拆成8+2,这里的j就是8,乘积是16;把10拆成9+1,这里的j就是9,乘积是9。第一个拆出来的数j如果超过当前被拆的整数i的一半以上那个乘积会越来越小。所以不考虑第一个拆出来的数j超过当前被拆的整数i的一半以上了)

三、再理解递推公式

我们来模拟两种情况,当i = 3和当i = 4的情况。

(当 i = 3时)

(当 i = 4时)

相关推荐
BothSavage6 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn6 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽7 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰1 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术1 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六1 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程
胡萝卜术1 天前
从“分数打架”到“排名投票”:为什么你的ChatBI必须用RRF?
算法·设计模式·面试
Asize1 天前
初识DFS 与 BFS:递归、队列与图遍历
算法