96. 不同的二叉搜索树

2021-08-23  本文已影响0人  justonemoretry
image.png

解法

class Solution {
    public int numTrees(int n) {
        // i个元素能组成的二叉搜索树能有几种
        int[] dp = new int[n + 1];
        // 初始化,0个和1个时都是1种
        dp[0] = 1;
        dp[1] = 1;
        for (int i = 2; i <= n; i++) {
            // j代表根节点的位置,取第几个元素
            for (int j = 1; j <= i; j++) {
                dp[i] += dp[j - 1] * dp[i - j];
            }
        }
        return dp[n];
    }
}
上一篇 下一篇

猜你喜欢

热点阅读