news 2026/3/2 22:46:38

【动态规划:96. 不同的二叉搜索树】刷题记录

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【动态规划:96. 不同的二叉搜索树】刷题记录

leetcode题目链接

题目:

给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的二叉搜索树有多少种?
返回满足题意的二叉搜索树的种数。
示例 1:
输入:n = 3
输出:5

示例 2:
输入:n = 1
输出:1
提示:1 <= n <= 19

1、确定dp数组以及下标的含义

dp[i] 表示 1 到 i 可以组成的互不相同二叉搜索树的种类。

2、确定递推公式

这个题目有些抽象,可以举例推导来找出递推关系。

n = 1 时,只有 1 种,dp[1] = 1。

n = 2 时,1、2 能组成的不同的二叉搜索数有下列 2 种 dp[2] = 2。

n = 3 时,1、2、3 能组成的不同的二叉搜索数有下列 5 种。

让每个数都做一次根节点,当 1 做根节点时,左子树只有为空这 1 种情况,右子树有 2 种情况;当 2 做根节点时,左子树只有 1 种情况,右子树也只有 1 种情况;当 3 做根节点时,左子树有 2 种情况,右子树只有 1 种情况。

在二叉搜索树中,一个节点的左右孩子还是一个二叉搜索树。

不难发现,1 做根节点时,右子树的那 2 种情况其实就是求 2 和 3 能组成的二叉搜索树有多少种,也就是 dp[2] 的值,左子树为空,空也可以看成是 1 种情况,也就是说 dp[0] = 1,那么 1 做根节点时一共有 dp[0] × dp[2] = 2 种情况;2 做根节点时,左右子树各有 1 个节点,那么就是 dp[1] × dp[1] = 1 种情况;3 做根节点时有 dp[2] × dp[0] = 2 种情况;所以当 n = 3 时,一共有 dp[0] × dp[2] + dp[0] × dp[2] + dp[0] × dp[2] = 5 种。

归纳一下,可以得出:

dp[i] += dp[j] * dp[(i - 1) - j];

3、dp数组如何初始化

dp[0] = 1,dp[0] 不在题目要求范围内,为了方便计算,我们定义 0 个节点时为 1 种情况。

4、确定遍历顺序

外层循环从左向右遍历 dp 数组,内层循环是求 dp[i] 的计算过程,j 表示左子树节点个数,(i - 1) - j 表示右子树节点个数。

for (int i = 1; i <= n; i++) { for (int j = 0; j < i; j++) { dp[i] += dp[j] * dp[(i - 1) - j]; } }

5、举例推导dp数组

可以尝试计算 dp[4] ,就不在此赘述了。

class Solution { public int numTrees(int n) { int[] dp = new int[n + 1]; dp[0] = 1; for (int i = 1; i <= n; i++) { for (int j = 0; j < i; j++) { dp[i] += dp[j] * dp[(i - 1) - j]; } } return dp[n]; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/2 9:20:25

如何彻底解决WVP-GB28181-Pro视频点播超时:3步快速优化指南

如何彻底解决WVP-GB28181-Pro视频点播超时&#xff1a;3步快速优化指南 【免费下载链接】wvp-GB28181-pro 项目地址: https://gitcode.com/GitHub_Trending/wv/wvp-GB28181-pro 还在为WVP-GB28181-Pro视频点播频繁超时而困扰吗&#xff1f;作为一名视频监控平台用户&am…

作者头像 李华
网站建设 2026/3/1 22:28:34

颠覆传统!Windows平台APK安装终极方案全解析

颠覆传统&#xff01;Windows平台APK安装终极方案全解析 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 还在为安卓模拟器的卡顿和资源占用而烦恼吗&#xff1f;想要在…

作者头像 李华
网站建设 2026/2/27 23:22:50

人教人学不会,事教人一次就好(用经历进行职业反思)

记录自己的一段经历&#xff0c;让自己开始反思一些问题。这段经历让我反思到&#xff1a;影响效率的永远不是技术本身&#xff0c;而是团队&#xff0c;社会&#xff0c;以及管理学&#xff08;技术只是基础支撑&#xff0c;应该把软件当工程学进行看待&#xff09;&#xff1…

作者头像 李华
网站建设 2026/3/2 6:38:47

Obsidian数据迁移全攻略:5步轻松导入Evernote、Notion等笔记

Obsidian数据迁移全攻略&#xff1a;5步轻松导入Evernote、Notion等笔记 【免费下载链接】obsidian-importer Obsidian Importer lets you import notes from other apps and file formats into your Obsidian vault. 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-…

作者头像 李华
网站建设 2026/2/27 11:47:44

【驱动量化交易12】教你如何通过股票数据api接口获取股票近年分红数据之Python、Java等多种主流语言实例代码演示通过股票数据接口获取数据

​ 如今&#xff0c;量化分析在股市领域风靡一时&#xff0c;其核心要素在于数据&#xff0c;获取股票数据&#xff0c;是踏上量化分析之路的第一步。你可以选择亲手编写爬虫来抓取&#xff0c;但更便捷的方式&#xff0c;莫过于利用专业的股票数据API接口。自编爬虫虽零成本&a…

作者头像 李华
网站建设 2026/2/28 21:02:03

8、调试模式与控制输出:探索Expect脚本的高级技巧

调试模式与控制输出:探索Expect脚本的高级技巧 1. 模式调试 在编写模式时,有几个关键要点需要注意。首先,要清楚构建模式的规则;其次,理解在Tel中表达模式的规则;最后,要明确预期字符串中的字符。任何一个步骤的误解都可能导致编写的模式无法匹配。 当模式未能按预期…

作者头像 李华