class Solution {
public:
int change(int amount, vector<int>& coins) {
vector <int> dp(amount+1,0);
dp[0]=1;
for(int i=0;i<coins.size();i++){
for(int j=coins[i];j<=amount;j++){
dp[j]+=dp[j-coins[i]];
}
}
return dp[amount];
}
};
另外你这个是不能从大到小遍历的 因为这样的话 你就落下了重复选取的情况
class Solution {
public:
int combinationSum4(vector<int>& nums, int target) {
vector<int>dp(target+1,0);
dp[0]=1;
for(int i=0;i<=target;i++){
for(int j=0;j<nums.size();j++){
if(i-nums[j]>=0&& dp[i] < INT_MAX - dp[i - nums[j]])
dp[i]+=dp[i-nums[j]];
}
}
return dp[target];
}
};
第二题还是要小心啊 虽然看起来是排列 实际上是组合!!!文章来源:https://www.toymoban.com/news/detail-614837.html
文章来源地址https://www.toymoban.com/news/detail-614837.html
到了这里,关于代码随想录 day44 完全背包的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!