Java动态规划方式解决不同的二叉搜索树
作者:刘婉晴 发布时间:2023-03-02 01:56:52
一、题目描述
给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。
来源:https://leetcode.cn/problems/unique-binary-search-trees/
二、思路
本题可以使用动态规划的方式解决,我们先来看一下大题思路。以 n = 3 为例,n = 3 时的不同的二叉搜索树数目,可以通过分别 以 1 为根节点,以 2 为根节点,以 3 为根节点 的不同的二叉搜索树的数量加和获得。
那么问题就来到了如何得到 以 1 为根节点,以 2 为根节点,以 3 为根节点 的不同二叉搜索树数量。这就是我们动态规划,主要处理的问题。
以 1 为根节点 时: 此时其左子树具有 dp[1-1] 种选择(左子树无节点),右子树具有 dp[3-1] 种选择(节点 2,3)
以 2 为根节点 时: 此时其左子树具有 dp[2-1] 种选择(节点 1),右子树具有 dp[3-2] 种选择(节点 3)
以 3 为根节点时: 此时其左子树具有 dp[3-1] 种选择(节点 1,2),右子树具有 dp[3-3] 中选择(右子树无节点)
因此 最终结果为
dp[1-1] * dp[3-1] + dp[2-1] * dp[3-2] + dp[3-1] * dp[3-3]
分析完了 n = 3 的情况,下面我们来看一下一般情况:
1. dp数组以及下标的含义:
dp[] 数组表示二叉搜索树数量,下标 i 表示当 n = i 时,所含的二叉搜索树数量
2. 确定递推公式:
dp[i] += dp[i-1] * dp[i-j] (其中 1<=j<=i, 表示以 j 为根节点的二叉搜索树)
3. dp数组如何初始化
当二叉树一个节点都没有,即 dp[0] 时 ,二叉搜索树只有一种情况 dp[0] = 1
当二叉树只有一个节点时,即 dp[1] 时,二叉搜索树只有一种情况 dp[1] = 1
4. 确定遍历顺序:
节点数为 3 的二叉搜索树种类数,需要用节点数为 2 的二叉搜索树推出,因此顺序遍历 从 3 ~ n 即可
三、代码
// 不同的二叉搜索树
public int numTrees(int n) {
int[] dp = new int[n+1];
dp[0] = 1;
dp[1] = 1; // 初始化动态规划数组
for(int i=2; i<n+1; i++){
for(int j=1; j<=i; j++){ // 分别以 1 ~ i 为根节点,计算二叉树种类数,累加到结果中
dp[i] += dp[j-1]*dp[i-j];
}
}
return dp[n];
}
来源:https://blog.csdn.net/liuwanqing233333/article/details/127298750


猜你喜欢
- 本文实例为大家分享了Unity实现物体左右移动效果的具体代码,供大家参考,具体内容如下效果如下代码:using UnityEngine;us
- 前言在框架中经常会会用到method.invoke()方法,用来执行某个的对象的目标方法。以前写代码用到反射时,总是获取先获取Method,
- java jpa自定义sql语句本篇只是为了再次记录自己又学习了jpa的使用,框架原生的通过解析方法名多适用于单表操作,自定义的sql查询则
- 苹果的iphone 有语音识别用的是Google 的技术,做为Google 力推的Android 自然会将其核心技术往Android 系统里
- 前言我们在前面介绍AssignAnalyzer时,对AssignAnalyzer.letInit(DiagnosticPosition, V
- 本文介绍了Android Studio 超级简单的打包生成apk,分享给大家,也给自己留个笔记。为什么要打包:apk文件就是一个包,打包就是
- 扩展Hibernate注解@CreationTimestamp,@UpdateTimestamp支持Java8新的时间类型Hibernate
- 使用filter对request body参数进行校验@Slf4jpublic class ParameterCheckServletReq
- 本文实例为大家分享了C++实现哈夫曼编码的具体代码,供大家参考,具体内容如下#include<iostream>#include
- 今天写这篇文章的缘由是前一段时间一个网友在我的博客上面留言,想要实现在GridLayout(相当于九宫格)中点击每项可左右滑动显
- 本文实例讲述了Android实现EditText控件禁止输入内容的方法。分享给大家供大家参考,具体如下:问题:android如何实现Edit
- Java Map.values()方法获取Map集合中的所有键值对象Java 集合类中的 Map.values() 方法用来获取
- 前言我们通常使用Spring boot做项目搭建的基础框架,必然少不了它的内置日志框架Logback,在spring-boot-starte
- 本文实例为大家分享了Java实现图形界面计算器的具体代码,供大家参考,具体内容如下 代码:import javax.swing.*
- 代码如下:/** * 动态生成SQ及SQL参数L * @param ve 接收到的消息的CHGLIST &nbs
- 项目开发中,经常会遇到定时任务的场景,Spring提供了@Scheduled注解,方便进行定时任务的开发概述要使用@Scheduled注解,
- 前言这几天听朋友说JPA很好用,根本不用写sql。我在想一个程序员不写sql还能叫程序员?而且越高级的工具封装越多的工具,可拓展性和效率就非
- JavaFx中其实也可以直接使用字体图标iconfont的,只需要加载ttf字体文件,之后设置unicode即可,具体可以看我给出的代码既然
- 本文实例讲述了C#实现文件压缩与解压的方法。分享给大家供大家参考,具体如下:在企业开发过程中经常会遇到文件的压缩与解压,虽然网上很多流行的压
- 背景:新年之际,微信微博支付宝红包是到处飞,但是,自己的手速总是比别人慢一点最后导致红包没抢到,红包助手就应运而生。需求:收到红包的时候进行