[算法手记] 动态规划,二叉树计数问题

前言: 本文将继续分享博主的做题记录

题目链接 : https://leetcode.cn/problems/unique-binary-search-trees/description/

一, 题目详情

二, 解题思路

二叉搜索树的特性是左子树的值都小于根节点,右子树的值都大于根节点的值, 题目让我们找出在节点数为n时,这样的二叉数总共有多少种,不同的根节点就会产生不同的情况

先来分析一下题目:

三, 代码参考

java 复制代码
class Solution {

    public int numTrees(int n) {

        int []dp = new int [n+1];

        //dp[i] :i 个节点能构成的不同 BST 的数量

        dp[0] = 1;

        //i:节点总数: j:根节点为j时,可以组成的BST个数

        for(int i = 1;i <= n;i++){

            for(int j = 1;j <= i;j++){

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

            }

        }

        return dp[n];

    }

}

以上就是有关动态规划的练习题解析,如有纰漏还请指出~~

相关推荐
爱喝雪碧的可乐6 小时前
2026 腾讯广告算法大赛优秀方案启示:行为条件化多模态自回归生成推荐摘要
算法·数据挖掘·回归·推荐系统·推荐算法
碧海银沙音频科技研究院6 小时前
音箱在加入 NN AEC(神经网络声学回声消除) 后出现反复重启问题解决
人工智能·深度学习·算法
叼烟扛炮8 小时前
C++ 知识点18 内部类
开发语言·c++·算法·内部类
YOGOD有神8 小时前
用AI自动从谷歌地图抓取海外客户,我跑了一次7小时的任务,结果出乎意料
算法
汉克老师8 小时前
GESP5级C++考试语法知识(十五、分治算法(二))
c++·算法·排序算法·分治算法·gesp5级·gesp五级
快瞳科技8 小时前
小样本学习在珍稀鸟类识别中的突破:仅需5张图,让AI认识濒危物种
算法
汉克老师8 小时前
GESP6级C++考试语法知识(五、格雷码)
c++·算法·位运算·异或·gesp6级·gesp六级·格雷码
Ulyanov8 小时前
《从质点到位姿:基于Python与PyVista的导弹制导控制全栈仿真》: 可视化革命——基于 PyVista 的 3D 战场构建与实时渲染
开发语言·python·算法·3d·系统仿真
,,?!,8 小时前
数据结构算法-排序算法
数据结构·算法·排序算法
小白编程锤炼9 小时前
深入解析:质量门禁
人工智能·算法·架构·vibe-coding