518. 零钱兑换 II
其实就是完全背包的路径次数的问题。
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];
}
};
● 377. 组合总和 Ⅳ
其实类似这种完全背包的排列方式问题我们可以把它理解成爬楼梯问题,这样的话就很好写了,只不过一步可以爬的方式有很多,所以内嵌一个for循环就好了。注意leetcode这里有一个次数的限制。
class Solution {
public:
int combinationSum4(vector<int>& nums, int target) {
vector<long long> dp(target+1,0);
dp[0]=1;
for(int i=1;i<=target;i++)
{
for(int j=0;j<nums.size();j++)
{
if(nums[j]<=i&&dp[i]+dp[i-nums[j]]<=INT_MAX)
dp[i]+=dp[i-nums[j]];
}
}
return dp[target];
}
};