【动态规划-卡特兰数——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];
    }
};

代码解析

相关推荐
ゞ 正在缓冲99%…20 小时前
leetcode35.搜索插入位置
java·算法·leetcode·二分查找
武昌库里写JAVA20 小时前
Mac下Python3安装
java·vue.js·spring boot·sql·学习
lifallen20 小时前
字节跳动Redis变种Abase:无主多写架构如何解决高可用难题
数据结构·redis·分布式·算法·缓存
青草地溪水旁21 小时前
设计模式(C++)详解—原型模式(1)
c++·设计模式·原型模式
feifeigo12321 小时前
星座SAR动目标检测(GMTI)
人工智能·算法·目标跟踪
怀旧,21 小时前
【C++】20. unordered_set和unordered_map
开发语言·c++
WWZZ202521 小时前
视觉SLAM第10讲:后端2(滑动窗口与位子图优化)
c++·人工智能·后端·算法·ubuntu·机器人·自动驾驶
alibli21 小时前
一文学会CMakeLists.txt: CMake现代C++跨平台工程化实战
开发语言·c++·系统架构
YuTaoShao21 小时前
【LeetCode 每日一题】36. 有效的数独
linux·算法·leetcode
MMjeaty21 小时前
map/multimap容器
数据结构·c++