https://leetcode.com/problems/unique-binary-search-trees/
//考虑根节点,设对于任意根节点k,有f(k)种树的可能。
//比k小的k-1个元素构成k的左子树。则左子树有f(k-1)种情况。
//比k大的n-k个元素构成k的右子树。则右子树有f(n-k)种情况。
//易知,左右子树相互独立,所以f(k)=f(k-1)*f(n-k)。
//综上,对于n,结果为k取1,2,3,...,n时,所有f(k)的和。
//用数组记录每个f(i)的值,记f(0)=1,f(1)=1。
//根据公式:f(k)=f(k-1)*f(n-k),访问数组中的元素。
//循环求和,结果更新到数组中。
class Solution {
public:
int numTrees(int n) {
vector<int> dp;
dp.push_back(1);
dp.push_back(1);
for(int i=2;i<=n;i++){
int sum=0;
for(int j=0;j<=i;j++){
sum+=(dp[j-1]*dp[i-j]);
}
dp.push_back(sum);
}
return dp.back();
}
};