今天两题都挺有难度,建议大家思考一下没思路,直接看题解,第一次做,硬想很难想出来。
递推公式,果然还是动态规划中的核心和基础,分析不出来递推公式,啥也不是。
343. 整数拆分
动规五部曲,分析如下:
- 确定dp数组(dp table)以及下标的含义
dp[i]:分拆数字i,可以得到的最大乘积为dp[i]。 - 确定递推公式
dp[i] = max(dp[i], max((i - j) * j, dp[i - j] * j)); - dp的初始化
dp[0] 和dp[1] 都是无意义的
需要从dp[2]开始 dp[2] = 1;(1*1)
class Solution {
public:
int integerBreak(int n) {
vector<int> dp(n + 1);
dp[2] = 1;
for (int i = 3; i <= n ; i++) {
for (int j = 1; j <= i / 2; j++) {
dp[i] = max(dp[i], max((i - j) * j, dp[i - j] * j));
}
}
return dp[n];
}
};
96.不同的二叉搜索树
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];
}
};