【动态规划-卡特兰数——96.不同的二叉搜索树】

1.题目解析

题目来源

|-------------------------------------------------------------------------------------------------------------------|
| 96.不同的二叉搜索树------力扣 |

测试用例

2.算法原理

1.状态表示

2.状态转移方程

3.初始化

需要用到前面位置的值,则需要初始化dp[0]为1,方便后续的填表

4.填表顺序

从前向后

5.返回值

根据状态表示返回dp[n]

3.实战代码

cpp 复制代码
class Solution {
public:
    int numTrees(int n) 
    {
        vector<int> dp(n+1);
        dp[0] = 1;
        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];
    }
};

代码解析

相关推荐
郝学胜-神的一滴几秒前
深度学习入门基石:PyTorch张量核心技术全解析
人工智能·pytorch·python·深度学习·算法·机器学习
稽稽稽稽不如人几秒前
《从零开始的java从入门到入土的学习生活——JavaWeb后端篇》Chapter18——JavaWeb后端篇学习记录——AOP 面向切面编程
java·学习·生活
sjg200104141 分钟前
GoFrame学习随便记4(待续)
学习
Frostnova丶7 分钟前
(10)LeetCode 560. 和为K的子数组
算法·leetcode·哈希算法
lucky_chaichai9 分钟前
学习《以openclaw为例介绍AI Agent的运作原理》
人工智能·学习
前端小趴菜~时倾9 分钟前
python爬虫学习第二课-流程控制
爬虫·python·学习
AI专业测评11 分钟前
2026年AI写作软件底层技术全景解析:长篇AI写网文的工程化实践与AI消痕算法基准测试
人工智能·算法·ai写作
biter down13 分钟前
C++ 设计不可被继承的类
java·开发语言·c++
Once_day14 分钟前
C++之《程序员自我修养》读书总结(12)
c++·编译与链接
浅念-16 分钟前
C++ 异常
开发语言·数据结构·数据库·c++·经验分享·笔记·学习