当前位置: 首页 > news >正文

代码随想录动态规划part02

动态规划part02

62.不同路径

代码随想录 

视频讲解:动态规划中如何初始化很重要!| LeetCode:62.不同路径_哔哩哔哩_bilibili

递归法

动态规划,当前状态是由上一个状态转化来的

这里初始化错误了,想法是对的右一和下一初值都是1,起点不需要走所以是0,但是在遍历时从起点开始,将右一和下一都清空了,导致整个dp数组值全为0;所以起点位置路径应为1,

        dp[0][0] = 1;

        //dp[0][1] = 1;

        //dp[1][0] = 1;

或者将第一列和第一行都初始化为1,然后从坐标[1,1]开始逐行遍历

63. 不同路径 II

https://programmercarl.com/0063.%E4%B8%8D%E5%90%8C%E8%B7%AF%E5%BE%84II.htmlhttps://programmercarl.com/0063.%E4%B8%8D%E5%90%8C%E8%B7%AF%E5%BE%84II.html

视频讲解:动态规划,这次遇到障碍了| LeetCode:63. 不同路径 II_哔哩哔哩_bilibili                 

后续搞清楚为什么上一题不加条件递推公式不会越界

遇到障碍把该位置dp值初始化为0,优化代码:

  1. 整数拆分

代码随想录  

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

回溯法 从1开始找出和等于n的组合(可重复)

终止条件

  1. 当和大于n
  2. Sum = n 计算乘积

上述可以优化,不用数组来保存乘积,直接比较每一个乘积结果只留最大值

动态规划

将n拆解成m个大小尽量接近的数值,乘积才会尽可能大

  1. 定义dp数组,dp[i]:数值i对应的最大乘积dp[i]
  2. 递推公式:将i拆出来的第一个数j(j从1开始遍历),dp[i] = j*dp[i-j];
    a) 为什么是dp[i-j]?
  • 拆分的第一个数字是j,还要对i-j继续拆,但是无论对i-j如何进行拆分,找到其对应的乘积最大值dp[i-j],然后*j就得到i在j拆分下的乘积最大值
  • J是从1开始遍历的,这样的话就包含了所有的拆分过程,在这其中找到最大的乘积

b) 为什么还要拆成j*(i-j)

举例说明若n=4,当j = 2,j*dp[j-i]=2*1=2,结果dp[4]=2

同理dp[3] = 1,

  1. dp初始化dp[1] = 0, dp[2]=1
  1. 为什么dp[1] = 0?dp[1] = 1也不妨碍结果
  1. 遍历顺序从3开始逐个拆分到n
  2. Debug

相关文章:

  • 【信息系统项目管理师】高分论文:论信息系统项目的范围管理(电网公司保供电可视化系统)
  • 图像处理算法面经1
  • 产品需求设计评审会:三步精准定位需求核心
  • std::enable_shared_from_this 模板类的作用是什么?
  • KEGG注释脚本kofam2kegg.py--脚本010
  • 小程序页面传值的多种方式
  • SQL语言
  • 力扣hot100_技巧_python版本
  • Multisim使用说明详尽版--(2025最新版)
  • 高效爬虫:一文掌握 Crawlee 的详细使用(web高效抓取和浏览器自动化库)
  • CS5346 - Interactivity in Visualization 可视化中的交互
  • Java 架构设计:从单体架构到微服务的转型之路
  • 大语言模型深度思考与交互增强
  • 策略模式随笔~
  • 适合单片机裸机环境的运行的软件定时器框架
  • Linux 下 Module 工具的介绍与使用
  • 深入解读:2024 可信数据空间建设及应用参考指南【附全文阅读】
  • Go 语言中的局部变量是分配在栈区还是堆区
  • 数据结构-限定性线性表 - 栈与队列
  • 在Mac上离线安装k3s
  • 国有六大行一季度合计净赚超3444亿,不良贷款余额均上升
  • 力箭二号火箭成功进行满载起竖试验,计划今年首飞发射轻舟飞船
  • 辽宁省全力开展辽阳一饭店火灾事故救援处置工作
  • 【社论】人工智能,年轻的事业
  • 西班牙葡萄牙突发全国大停电,欧洲近年来最严重停电事故何以酿成
  • ​关键词看中国经济“一季报”:韧,长期向好看底气