@ 代码随想录算法训练营第7周(C语言)|Day41(动态规划)
Day44、动态规划(包含题目 ● 518. 零钱兑换 II ● 377. 组合总和 Ⅳ )
518. 零钱兑换 II
题目描述
给定不同面额的硬币和一个总金额。写出函数来计算可以凑成总金额的硬币组合数。假设每一种面额的硬币有无限个。
题目解答
int change(int amount, int* coins, int coinsSize) {
int dp[amount+1];
for(int i=0;i<=amount;i++){
dp[i]=0;
}
dp[0]=1;
for(int i=0;i<coinsSize;i++){
for(int j=coins[i];j<=amount;j++){
dp[j]+=dp[j-coins[i]];
}
}
return dp[amount];
}
题目总结
完全背包组合问题 先物品后背包。
377. 组合总和 Ⅳ
题目描述
给你一个由 不同 整数组成的数组 nums ,和一个目标整数 target 。请你从 nums 中找出并返回总和为 target 的元素组合的个数。
题目解答
int combinationSum4(int* nums, int numsSize, int target) {
int dp[target+1];
for(int i=0;i<=target;i++){
dp[i]=0;
}
//memset(dp, 0 , sizeof(int)*(target+1));
dp[0]=1;
for(int i=1;i<=target;i++){
for(int j=0;j<numsSize;j++){
if(nums[j]<=i && dp[i]<INT_MAX-dp[i-nums[j]]){
dp[i]+=dp[i-nums[j]];
}
}
}
return dp[target];
}
题目总结
完全背包排列问题,先背包后物品。