算法训练营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];
    }
};
相关推荐
源代码•宸2 分钟前
Golang原理剖析(程序初始化、数据结构string)
开发语言·数据结构·经验分享·后端·golang·string·init
HalvmånEver3 分钟前
Linux:深入剖析 System V IPC上(进程间通信八)
linux·运维·数据库·c++·system v·管道pipe
空山新雨后、7 分钟前
从 CIFAR 到 ImageNet:计算机视觉基准背后的方法论
人工智能·深度学习·算法·计算机视觉
m0_7482500312 分钟前
C++ Web 编程
开发语言·前端·c++
YuTaoShao17 分钟前
【LeetCode 每日一题】712. 两个字符串的最小ASCII删除和——(解法三)状态压缩
算法·leetcode·职场和发展
liliangcsdn20 分钟前
LLM训练中batchsize与过拟合和泛化的关系
人工智能·算法·机器学习
承渊政道21 分钟前
C++学习之旅【C++String类介绍】
c语言·c++·vscode·学习
muddjsv24 分钟前
什么是算法?——现代视角下的一次凝视
算法
laplace012325 分钟前
智能体经典范式构建
算法·langchain·大模型·agent
小雨下雨的雨26 分钟前
Flutter鸿蒙共赢——色彩的流变:流体梯度网格与现代视觉重构
算法·flutter·华为·重构·交互·harmonyos·鸿蒙