518.零钱兑换II
今天的这两道题都是以完全背包为理论基础,零钱兑换II是算组合总数,dp[i]表示总和为i的组合数,dp[i]+=dp[i-nums[j]],dp[i]相当于把之前的所有情况累加起来,求组合总数是先遍历物品再遍历背包。
https://leetcode.cn/problems/coin-change-ii/description/
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.组合总和IV
这道题是求排列的组合数,所以是先遍历背包再遍历物品。
https://leetcode.cn/problems/combination-sum-iv/description/
class Solution {
public:
int combinationSum4(vector<int>& nums, int target) {
vector<int>dp(target+1,0);
dp[0]=1;
for(int j=1;j<=target;j++)
{
for(int i=0;i<nums.size();i++)
{ if(j>=nums[i]&&dp[j] < INT_MAX - dp[j - nums[i]])
{dp[j]+=dp[j-nums[i]];}
}
}
return dp[target];
}
};