代码随想录算法训练营第三十七天-2|动态规划part2

开始完全背包

注意01背包与完全背包的区别

518. 零钱兑换 II

题目链接:518. 零钱兑换 II - 力扣(LeetCode)

文章讲解:代码随想录

思路:

用dp【i】【j】表示从0-i任选硬币 有多少种方法装满背包j

递推公式:

dp[i][j] = dp[i - 1][j] + dp[i][j - coins[i]];

cpp 复制代码
class Solution {
public:
    int change(int amount, vector<int>& coins) {
        //定义dp【i】【j】表示从0-i任选硬币 有多少种方法装满背包j
        vector<vector<double>>dp(coins.size(),vector<double>(amount+1,0));
        //初始化
        for(int j=0;j<=amount;j++){
            if(j%coins[0]==0) dp[0][j]=1;
        }
        for(int i=0;i<coins.size();i++){
            dp[i][0]=1;
        }

        for(int i=1;i<coins.size();i++){
            for(int j=1;j<=amount;j++){
                if (coins[i] > j) dp[i][j] = dp[i - 1][j]; 
                else dp[i][j] = dp[i - 1][j] +  dp[i][j - coins[i]];
                //容量为j 不放物品i有dp[i - 1][j]多种方法
                //容量为j - coins[i] 物品i 有dp[i][j- coins[i]]种方法
            }
        }
        return int(dp[coins.size()-1][amount]);      
    }
};

事实上 这道题类似于01背包问题的目标和 这是一道完全背包的目标和

区别在于遍历顺序为从头到尾遍历

cpp 复制代码
class Solution {
public:
    int change(int amount, vector<int>& coins) {

        //类似目标和
        vector<double>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 int(dp[amount]);
        

    }
};

377. 组合总和 Ⅳ

题目链接:377. 组合总和 Ⅳ - 力扣(LeetCode)

文章讲解:代码随想录

思路:

这道题与上题的零钱兑换二很像 区别在于 这是排列问题

所以遍历顺序有要求

因为上题的遍历先遍历物品 所以隐含了一个物品的排列顺序 一种特定的排列顺序

那么本题 先遍历背包 即在背包容量为j下能有多少种装法(包含了不同排列顺序了的)

所以先遍历背包容量

cpp 复制代码
class Solution {
public:
int combinationSum4(vector<int>& nums, int target) {
    vector<long>dp(target+1,0);
    dp[0]=1;
    for(int j=0;j<=target;j++){
        for(int i=0;i<nums.size();i++){
            if(j-nums[i]>=0&&dp[j]<LONG_MAX-dp[j-nums[i]]){            
                dp[j]+=dp[j-nums[i]];
                }
        }
    }
    return dp[target];
}
};
相关推荐
IT古董1 分钟前
【第五章:计算机视觉-项目实战之目标检测实战】2.目标检测实战:中国交通标志检测-(2)中国交通标志检测数据格式转化与读取
算法·目标检测·计算机视觉
MobotStone7 分钟前
LLM 采样入门到进阶:理解与实践 Top-K、Top-P、温度控制
算法
杨小码不BUG39 分钟前
CSP-J/S初赛知识点精讲-图论
c++·算法·图论··编码·csp-j/s初赛
LeaderSheepH2 小时前
常见的排序算法
数据结构·算法·排序算法
青云交3 小时前
Java 大视界 -- Java 大数据在智能公交调度优化与准点率提升中的应用实践(416)
java·动态规划·flink cep·spark mllib·智能公交调度·杭州公交案例·准点率提升
周杰伦_Jay3 小时前
【图文详解】强化学习核心框架、数学基础、分类、应用场景
人工智能·科技·算法·机器学习·计算机视觉·分类·数据挖掘
violet-lz3 小时前
Linux静态库与共享库(动态库)全面详解:从创建到应用
算法
贝塔实验室3 小时前
ADMM 算法的基本概念
算法·数学建模·设计模式·矩阵·动态规划·软件构建·傅立叶分析
235163 小时前
【LeetCode】3. 无重复字符的最长子串
java·后端·算法·leetcode·职场和发展
微笑尅乐4 小时前
神奇的位运算——力扣136.只出现一次的数字
java·算法·leetcode·职场和发展