一、相关编程题
1.1 组合总和Ⅳ(似包非包)
题目链接
题目描述
算法原理
提示:根据发现的重复子问题推导状态转移方程
编写代码
class Solution {
public:
int combinationSum4(vector<int>& nums, int target) {
vector<double> dp(target+1);
dp[0] = 1;
for(int i = 1; i <= target; ++i)
{
for(auto e : nums)
if(i >= e)
dp[i] += dp[i-e];
}
return dp[target];
}
};
1.2 不同的二叉搜索树(卡特兰数)
题目链接
题目描述
算法原理
编写代码
class Solution {
public:
int numTrees(int n) {
vector<int> dp(n+1);
dp[0] = 1;
for(int i = 1; i <= n; ++i) //节点个数
{
for(int j = 1; j <= i; ++j) //选择任意一个数作为根节点
dp[i] += dp[j-1]*dp[i-j];
}
return dp[n];
}
};