算法训练营day46

完全背包和01背包的区别就是是否可以重复使用,在代码上就是 j 的 for 循环从前向后遍历还是从后向前遍历

题目:52. 携带研究材料(第七期模拟笔试) (kamacoder.com)

复制代码
#include<iostream>
#include<vector>

using namespace std;

int main() {
    int N, V;
    cin >> N >> V;
    vector<int> wegiht(N, 0);
    vector<int> val(N, 0);
    for(int i = 0;i < N;i++) {
        cin >> wegiht[i] >> val[i];
    }
    vector<int> dp(V + 1, 0);
    for(int i = 0;i < N;i++) {
        for(int j = wegiht[i];j <= V;j++) {
            dp[j] = max(dp[j], dp[j - wegiht[i]] + val[i]);
        }
    }
    cout << dp[V] << endl;
    return 0;
}

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

先物品再背包是组合,先背包再物品是排列

复制代码
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];
    }
};

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

复制代码
class Solution {
public:
    int combinationSum4(vector<int>& nums, int target) {
        vector<int> 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] < INT_MAX - dp[j - nums[i]]) {
                    dp[j] += dp[j - nums[i]];
                }
            }
            for(int j = 0;j <= target;j++) {
                cout << dp[j] << ",";
            }
            cout << "---------" << endl;
        }
        return dp[target];
    }
};
相关推荐
Fleshy数模11 分钟前
多分类任务下的经典机器学习算法实战:LR、RF、SVM等对比分析
算法·机器学习·分类
草莓熊Lotso14 分钟前
Linux IPC 进阶:System V 消息队列与信号量(含内核管理深度解析)
linux·运维·服务器·数据库·c++·人工智能·mysql
风吹乱了我的头发~3 小时前
Day52:2026年3月20日打卡
算法
2401_831824968 小时前
基于C++的区块链实现
开发语言·c++·算法
We་ct8 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
愣头不青8 小时前
238.除了自身以外数组的乘积
数据结构·算法
汉克老师8 小时前
GESP5级C++考试语法知识(六、链表(一)单链表)
c++·链表·单链表·快慢指针·进阶·gesp5级·gesp五级
人工智能AI酱8 小时前
【AI深究】逻辑回归(Logistic Regression)全网最详细全流程详解与案例(附大量Python代码演示)| 数学原理、案例流程、代码演示及结果解读 | 决策边界、正则化、优缺点及工程建议
人工智能·python·算法·机器学习·ai·逻辑回归·正则化
WangLanguager8 小时前
逻辑回归(Logistic Regression)的详细介绍及Python代码示例
python·算法·逻辑回归
m0_518019488 小时前
C++与机器学习框架
开发语言·c++·算法