代码随想录|Day34|动态规划03|343.整数拆分、96.不同的二叉搜索树

343.整数拆分

动规五步:

  1. 确定 dp[i] 含义:拆分数字 i,可以获得的最大乘积为 dp[i]
  2. 递推公式:dp[i] = max(j * (i - j), j * dp[i - j])。i 可以被拆解为两个数(j 和 i - j)或者多个数(jdp[i - j]),因为根据我们的 dp定义,这里的 dp[i - j] 意思为 拆分数字 i - j
  3. dp数字初始化:题目要求 n >= 2,而我们知道拆分 2,最大乘积为 1*1 = dp[2]
  4. 遍历顺序:从左至右,因为 dp[i] 需要用到 dp[i-j]。
  5. 打印dp数组
class Solution:def integerBreak(self, n: int) -> int:# 我们使用下标表示数字的大小,# dp数组需要存储 0 到 n 共 n+1 个数字dp = [0] * (n + 1)dp[2] = 1 * 1for i in range(3, n + 1):for j in range(1, i):# 对于每个 j,都会更新一个 dp[i],需要其中最大的 dp[i]dp[i] = max(dp[i], max(j * (i - j), j * dp[i - j]))return dp[n]

96.不同的二叉搜索树

我们可以画出 n = 1, 2, 3的情况,找出规律,如下图:

 

在 n = 3 的时候:

  • 若根节点为1,根据二叉搜索树的性质,左子树没有节点,右子树2个节点,其右子树的情况与 n = 2 的时候一样。
  • 若根节点为3,根据二叉搜索树的性质,左子树2个节点,右子树没有节点,其左树的情况与 n = 2 的时候一样。
  • 若根节点为2,根据二叉搜索树的性质,左子树1个节点,右子树1个节点,其左右子树的情况与 n = 1 的时候一样。

因此,dp[3] = 以1为头节点的搜索树数量 + 以2为头节点的搜索树数量 + 以3为头节点的搜索树数量。

  • 1为头节点的搜索树数量 = 左子树有0个节点的搜索树数量 * 右子树有2个节点的搜索树数量
  • 2为头节点的搜索树数量 = 左子树有1个节点的搜索树数量 * 右子树有1个节点的搜索树数量
  • 3为头节点的搜索树数量 = 左子树有2个节点的搜索树数量 * 右子树有0个节点的搜索树数量

有2个元素的搜索树数量就是dp[2]。

有1个元素的搜索树数量就是dp[1]。

有0个元素的搜索树数量就是dp[0]。

所以dp[3] = dp[2] * dp[0] + dp[1] * dp[1] + dp[0] * dp[2]

动规五步曲:

  1. dp数组的含义:由1到i为节点组成的二叉搜索树的个数为 dp[i]。
  2. 递推公式:dp[i] += dp[j - 1] * dp[i - j]1i 为头节点的所有搜索树之和。假设用 j 来遍历,以 j 为头节点的搜索树中,左子树有 j - 1 个节点,右子树有 i - j 个节点。
  3. 初始化:dp[0] = 1。如果只有一个节点,其也是一个二叉搜索树,因此 dp[1] = 1。根据递推公式:dp[1] = dp[1 - 1] * dp[1 - 1] = dp[0] * dp[0] ,因此虽然 dp[0] 没有意义,但必须初始化为 1
  4. 遍历顺序:dp[i] 由小于 i 的节点得出,因此从小到大。
  5. 打印dp数组
class Solution:def numTrees(self, n: int) -> int:# 如果我们显式初始化 dp[1] = 1,则会报错。# dp[1] 依赖下方的代码来更新,必须保持 dp[1]被初始化为0dp = [0] * (n + 1)dp[0] = 1for i in range(1, n + 1):for j in range(1, i + 1):dp[i] += dp[j - 1] * dp[i - j]return dp[n]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/601225.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

苍穹外卖Day10——总结10

前期文章 文章标题地址苍穹外卖Day01——总结1https://lushimeng.blog.csdn.net/article/details/135466359苍穹外卖Day02——总结2https://lushimeng.blog.csdn.net/article/details/135484126苍穹外卖Day03——总结3https://blog.csdn.net/qq_43751200/article/details/1363…

JS 轮播图点击左右切换

点击左右按钮实现轮播图切换图片 style: *{margin: 0;padding: 0;margin: auto;}#img1{width: 300px;height: 300px;position: relative;}#butto1{width: 50px;height: 100px;font-size: 50px;border: none;background-color: hsla(0, 0%, 0%, 0.2);position: abs…

管易云和金蝶云星空接口打通对接实战

管易云和金蝶云星空接口打通对接实战 对接系统:管易云 管易云是金蝶旗下专注提供电商企业管理软件服务的子品牌,先后开发了C-ERP、EC-OMS、EC-WMS、E店管家、BBC、B2B、B2C商城网站建设等产品和服务,涵盖电商业务全流程。 接入系统&#xff1…

用二八定律分析零售数据,不就更直观了吗?

20%的商品贡献了80%的销售金额,你会不会想知道这些商品的销售金额、毛利、销售金额累计占比、毛利累计占比,会不会想知道这些商品在各个门店的销售表现?看是否能进一步提高销售金额,提高毛利。这样的报表该怎么做?奥威…

jdk8新特性 方法引用

简介 lambda表达式是用来简化匿名内部类的方法引用 使用来简化 lambda表达式的 方法引用的标志 两个冒号 静态方法 静态方法 class CompareByAge {public static int compare(Student o1, Student o2) {return o1.getAge() - o2.getAge();} }静态方法引用 Arrays.sort(students…

学习人工智能:为何PyTorch深度学习框架不可或缺

在人工智能(AI)的浩瀚领域中,深度学习作为其核心分支,正以其强大的数据处理能力、模式识别能力和预测能力引领着科技的飞速发展。而在深度学习的众多工具与框架中,PyTorch无疑是一颗璀璨的明星。本文将从PyTorch的特点…

开源软件技术社区方案

开源软件技术社区是一个由开发者、贡献者、用户和维护者组成的共享平台,主要目的是打造技术、软件产品良性互动、开源技术安全可控的软件生态环境,实现可复用应用或服务的快速部署与使用、完成资源与能力的高度共享、促进社区成员的共建共赢,…

代码随想录day42|背包问题、416. 分割等和子集

背包问题: 01 背包 二维数组dp[i][j]解法 纯01背包:有n件物品和一个最多能背重量为w 的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品只能用一次,求解将哪些物品装入背包里物品价值总和最大。 dp[i][j]:从…

电力变压器数据集介绍和预处理

1 电力变压器数据集介绍 1.1 数据背景 在这个Github仓库中,作者提供了几个可以用于长序列时间序列问题的数据集。所有数据集都经过了预处理,并存储为.csv文件。数据集的范围从2016/07到2018/07。 ETT-small: 含有2个电力变压器(来自2个站点…

代码随想录算法训练营Day14|二叉树理论基础和递归遍历

代码随想录卡哥视频 理论基础 需要了解 二叉树的种类,存储方式,遍历方式 以及二叉树的定义 文章讲解:代码随想录 递归遍历 (必须掌握) 二叉树的三种递归遍历掌握其规律后,其实很简单 题目链接/文章讲解/…

从尾到头打印链表

😀前言 链表问题一直是我在算法学习过程中经常遇到的挑战之一。其中,从尾到头打印链表的问题尤其引起了我的兴趣。这个问题看似简单,实际上涉及到了链表的遍历和逆序输出,需要我们灵活运用数据结构和算法知识来解决。在解决这个问…

调整雷达图

首先是具体对于雷达图的要求 相应的要求难点主要集中于 一 这个 标签的大小的调整通常不进行调整他会按照自定义的格式进行调整,但按要求来说的话是不符合的这是需要注意到的一点 需要在legend中设置下面参数进行调整 itemWidth : 17,itemHeight: 15 二 y轴上的刻…