Unique Binary Search Trees

07/11/2016 Tree Dynamic Programming

Question

Given an integer n, how many structurally unique BST’s (binary search trees) that store values 1…n.

For example,

Given n = 3, your program should return all 5 unique BST’s shown below.

    1         3     3      2      1
     \       /     /      / \      \
      3     2     1      1   3      2
     /     /       \                 \
    2     1         2                 3

Solution

Result: Accepted Time: 0 ms

Here should be some explanations.

#define MAXN 256
int bst[MAXN]={0};
int numTrees(int n) {
    if(!bst[0])
    {
        bst[0] = 1;
        for(int k = 1; k < MAXN; k++)
            for(int  i= 0; i < k; i++)
                bst[k] += bst[i] * bst[k-1-i];
    }
    return bst[n];
}

Complexity Analytics

  • Time Complexity: O(1)
  • Space Complexity: O(n)