Given n, how many structurally unique BST's (binary search trees) that store values 1...n?
Example
Given n = 3, there are a total of 5 unique BST's.
1 3 3 2 1 \ / / / \ \ 3 2 1 1 3 2 / / \ \ 2 1 2 3
class Solution { public: /** * @paramn n: An integer * @return: An integer */ int numTrees(int n) { if (n < 2) return 1; int ret = 0; for(int i = 0; i <n; i++) ret += numTrees(i)*numTrees(n-i-1); return ret; } };
class Solution { public: /** * @paramn n: An integer * @return: An integer */ int numTrees(int n) { vector<int> count(n+1, 0); count[0] = 1; for(int i = 1; i <= n; i++) for(int j = 0; j <i; j++) count[i] += count[j]*count[i-j-1]; return count[n]; } };
No comments:
Post a Comment