C++背包问题

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

const int MAXN = 1005;

int N, V;
int w[MAXN], v[MAXN];
int dp[MAXN][MAXN];

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

解释:

  1. wv 数组分别表示每个物品的重量和价值。
  2. dp[i][j] 表示前 i 个物品在背包容量为 j 的情况下的最大价值。
  3. 状态转移方程:dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - w[i]] + v[i]),即选择当前物品或不选择当前物品。
  4. 循环遍历每一个物品和每一个背包容量,计算出最大价值。
  5. 输出 dp[N][V] 即为答案。
相关推荐
午彦琳6 分钟前
leetcode hot 100_49,128
算法·leetcode·职场和发展
..过云雨10 分钟前
【负载均衡oj项目】01. 项目概述及准备工作
linux·c++·html·json·负载均衡
郝学胜-神的一滴12 分钟前
深度解析:Python元类手撸ORM框架,解锁底层编程魔法
数据结构·数据库·python·算法·职场和发展
yuuki23323313 分钟前
【C++ 智能指针全解析】从内存泄漏痛点到 RAII + unique/shared/weak_ptr 手撕实现
开发语言·c++
big_rabbit050218 分钟前
[算法][力扣219]存在重复元素2
数据结构·算法·leetcode
闻缺陷则喜何志丹25 分钟前
【构造 前缀和】P8902 [USACO22DEC] Range Reconstruction S|普及+
c++·算法·前缀和·洛谷·构造
摸鱼仙人~28 分钟前
动态规划求解 20 个通用模板
算法·动态规划
记忆多33 分钟前
c++内联函数
算法
仟濹1 小时前
【算法打卡day20(2026-03-12 周四)算法/技巧:哈希表,双指针,字符串交换处理】5个题
数据结构·算法·散列表
老四啊laosi1 小时前
[C++进阶] 16. 继承
c++·继承