返回顶部
首页 > 资讯 > 后端开发 > Python >Java动态规划方式解决不同的二叉搜索树
  • 741
分享到

Java动态规划方式解决不同的二叉搜索树

Java二叉搜索树Java动态规划二叉搜索树Java动态规划 2022-11-13 18:11:48 741人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录一、题目描述二、思路三、代码一、题目描述 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。 来

一、题目描述

给你一个整数 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];
    }

到此这篇关于Java动态规划方式解决不同的二叉搜索树的文章就介绍到这了,更多相关Java二叉搜索树内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java动态规划方式解决不同的二叉搜索树

本文链接: https://lsjlt.com/news/169836.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java动态规划方式解决不同的二叉搜索树
    目录一、题目描述二、思路三、代码一、题目描述 给你一个整数 n ,求恰由 n 个节点组成且节点值从 1 到 n 互不相同的 二叉搜索树 有多少种?返回满足题意的二叉搜索树的种数。 来...
    99+
    2022-11-13
    Java二叉搜索树 Java动态规划二叉搜索树 Java动态规划
  • Java中关于二叉树的概念以及搜索二叉树详解
    目录一、二叉树的概念为什么要使用二叉树?树是什么?树的相关术语!根节点路径父节点子节点叶节点子树访问层(深度)关键字满二叉树完全二叉树二叉树的五大性质二、搜索二叉树插入删除hello...
    99+
    2024-04-02
  • Java二叉搜索树与数组查找的方法
    本篇内容介绍了“Java二叉搜索树与数组查找的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!题目一 解法class ...
    99+
    2023-06-29
  • java二叉树的遍历方式详解
    目录一、前序遍历(递归和非递归)二、中序遍历(递归和非递归)三、后序遍历(递归和非递归)四、层序遍历总结一、前序遍历(递归和非递归) 前序遍历就是先遍历根再遍历左之后是右 根左右 ...
    99+
    2024-04-02
  • Java 数据结构篇-实现二叉搜索树的核心方法
    🔥博客主页: 【小扳_-CSDN博客】 ❤感谢大家点赞👍收藏⭐评论✍  文章目录         1.0 二叉搜索树的概述         2.0 二叉搜索树的成员变量及其构造方法         ...
    99+
    2024-01-21
    数据结构 java 链表 算法
  • Java二叉树的四种遍历方式详解
    二叉树的四种遍历方式: 二叉树的遍历(traversing binary tree)是指从根结点出发,按照某种次序依次访问二叉树中所有的结点,使得每个结点被访问依次且仅被访...
    99+
    2024-04-02
  • 图解二叉树的三种遍历方式及java实现代码
    二叉树(binary tree)是一颗树,其中每个节点都不能有多于两个的儿子。1.二叉树节点作为图的特殊形式,二叉树的基本组成单元是节点与边;作为数据结构,其基本的组成实体是二叉树节点(binary tree node),而边则对应于节点之...
    99+
    2023-05-31
    java 二叉树 遍历
  • 通俗易懂讲解C语言与Java中二叉树的三种非递归遍历方式
    详解二叉树的三种非递归遍历方式(附C、java源码) 前言 二叉树的递归遍历方式很简单,三种递归遍历方式的区别,只是printf放的位置不一样而已,这里就不多讲了。把前序遍历代码贴在...
    99+
    2024-04-02
  • win8无线网卡搜索不到信号但无线设备驱动正常的解决方法
      预装Win8中文版系统,无线设备驱动正常,但搜索不到信号。飞行模式确认为关闭。如下图所示:   分析原因:Win8系统设置里新增加了对无线网卡的控制,需要启用才能连接无线网络。   解决方案:   1...
    99+
    2022-06-04
    解决方法 无线网卡 信号
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作