【第22期】观点:IT 行业加班,到底有没有价值?

[LeetCode]Unique Binary Search Trees, 解题报告

原创 2013年12月05日 11:11:18

前言

今天准备把LeetCode上AC Rates在30%以上的题目全部收尾,这道题目也是我在这个AC Rate上遇到的感觉最麻烦的一道题目,分享一下自己的解题思路



而且这道题目AC Rate竟然这么高


题目

Given n, how many structurally unique BST's (binary search trees) that store values 1...n?

For example,
Given n = 3, there are a total of 5 unique BST's.




思路

这道题目我想了两天,一直试图找出递推的规律,昨晚才想明白思路有问题,这应该是一道典型的动态规划题目,因为有重叠的子问题,当前决策依赖于子问题的解

我设dp[i]表示共有i个节点时,能产生的BST树的个数

n == 0 时,空树的个数必然为1,因此dp[0] = 1

n == 1 时,只有1这个根节点,数量也为1,因此dp[1] = 1

n == 2时,有两种构造方法,如下图所示:


因此,dp[2] = dp[0] * dp[1] + dp[1] * dp[0]

n == 3时,构造方法如题目给的示例所示,dp[3] = dp[0] * dp[2] + dp[1] * dp[1] + dp[2] * dp[0]

同时,当根节点元素为 1, 2, 3, 4, 5,  ..., i, ..., n时,基于以下原则的BST树具有唯一性:

以i为根节点时,其左子树构成为[0,...,i-1],其右子树构成为[i+1,...,n]构成

因此,dp[i] = sigma(dp[0...k] * dp[k+1...i]) 0 <= k < i - 1


代码

import java.util.Scanner;


public class UniqueBinarySearchTrees {
    public static int numTrees(int n) {
        int i, j, dp[] = new int[n + 1];

        if (n == 0) return 1;

        dp[0] = dp[1] = 1;

        for (i = 2; i <= n; i++) {
            dp[i] = 0;
            for (j = 0; j < i; j++) {
                dp[i] += dp[j] * dp[i - j - 1];
            }
        }

        return dp[n];
    }


    public static void main(String[] args) {
        int n, num;
        Scanner cin = new Scanner(System.in);

        while (cin.hasNext()) {
            n = cin.nextInt();
            num = numTrees(n);

            System.out.println(num);
        }

        cin.close();
    }
}



版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

Unique Binary Search Trees——唯一的二叉搜索树

原题: Given n, how many structurally unique BST's (binary search trees) that store values 1...n? =>给一个...

Unique Binary Search Trees -- LeetCode

原题链接: http://oj.leetcode.com/problems/unique-binary-search-trees/  这道题要求可行的二叉查找树的数量,其实二叉查找树可以任意取根,只要...

程序员升职加薪指南!还缺一个“证”!

CSDN出品,立即查看!

LeetCode 96:Unique Binary Search Trees

Given n, how many structurally unique BST's (binary search trees) that store values 1...n? For ex...

Unique Binary Search Trees II

Unique Binary Search Trees II@(leetcode)[枚举, DFS]Given an integer n, generate all structurally uniqu...
  • lqcsp
  • lqcsp
  • 2016-08-21 15:54
  • 204

LeetCode96:Unique Binary Search Trees

Given n, how many structurally unique BST's (binary search trees) that store values 1...n? For ex...

LeetCode || Unique Binary Search Trees

Unique Binary Search Trees  Total Accepted: 11525 Total Submissions: 32497My Submissions ...

LeetCode | Unique Binary Search Trees II

题目: Given n, generate all structurally unique BST's (binary search trees) that store values 1.....

LeetCode_Unique Binary Search Trees

LeetCode_Unique Binary Search Trees 解题思路

leetcode -- Unique Binary Search Trees II

leetcode -- Unique Binary Search Trees II

[leetcode] 95. Unique Binary Search Trees II 解题报告

题目链接:https://leetcode.com/problems/unique-binary-search-trees-ii/ Given n, generate all structural...
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)