当前位置:首页 > 题解目录 > 正文内容

【动态规划】完全背包

亿万年的星光1年前 (2024-12-06)题解目录1055

【题目描述】

设有n种物品,每种物品有一个重量及一个价值。但每种物品的数量是无限的,同时有一个背包,最大载重量为m,今从n种物品中选取若干件(同一种物品可以多次选取),使其重量的和小于等于m,而价值的和为最大。

【输入】

第一行:两个整数,m(背包容量,m<=200)和n(物品数量n<=30);

第2....N+1行:每行二个整数Wi,Ci表示每个物品的重量和价值。

【输出】

仅一行,一个数,表示最大总价值。

【输入样例】

10 4
2 1
3 3
4 5
7 9


【输出样例】

max=12

【题目分析】

  1. 输入部分

    • 首先读取两个整数,m 为背包的最大容量,n 为物品的数量。

    • 接着,通过循环读取每个物品的信息,包括其重量 Wi 和价值 Ci

  2. 动态规划数组

    • 创建一个长度为 m + 1 的数组 dp,用于存储在各个可能的背包容量下获得的最大价值。

  3. 状态转移处理

    • 外层循环遍历所有的物品(从 0 到 n-1)。

    • 内层循环从当前物品的重量开始迭代到背包的最大容量 m。这是因为,对于无限数量的物品,可以多次选择同一物品,所以这里的内层循环的起始位置应该是 weights[i]

    • 在每一步更新 dp[j] 时,计算不选择和选择当前物品所能得到的最大价值,并选择较大值进行更新。

  4. 输出结果

    • 最后,打印出在背包最大容量 m 下的最大总价值。



【参考代码】

#include <iostream>
#include <algorithm>

using namespace std;

int main() {
    int m, n;
    cin >> m >> n; // 读取背包容量 m 和物品数量 n

    int weights[30]; // 存放物品重量,大小为最大数量 n
    int values[30];  // 存放物品价值,大小为最大数量 n
    int dp[201] = {0}; // dp 数组初始化,大小为最大容量 m + 1,初始值为 0

    // 读取每个物品的重量和价值
    for (int i = 0; i < n; i++) {
        cin >> weights[i] >> values[i];
    }

    // 动态规划处理
    for (int i = 0; i < n; i++) {
        for (int j = weights[i]; j <= m; j++) { // 从 weights[i] 开始更新
            dp[j] = max(dp[j], dp[j - weights[i]] + values[i]);
        }
    }

    // 输出最大总价值
    cout << "max=" << dp[m] << endl;

    return 0;
}


    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    分享给朋友:
    返回列表

    上一篇:植树节

    下一篇:【题解】阳光

    相关文章

    剪刀石头布

    【题目描述】石头剪子布,是一种猜拳游戏。起源于中国,然后传到日本、朝鲜等地,随着亚欧贸易的不断发展它传到了欧洲,到了近现代逐渐风靡世界。简单明了的规则,使得石头剪子布没有任何规则漏洞可钻,单次玩法比拼...

    【题解】搭配购买

    【题目描述】Joe觉得云朵很美,决定去山上的商店买一些云朵。商店里有n朵云,云朵被编号为1,2,…,n,并且每朵云都有一个价值。但是商店老板跟他说,一些云朵要搭配来买才好,所以买一朵云则与这朵云有搭配...

    线段

    题目描述在一个数轴上有n条线段,现选取其中k条线段使得这k条线段两两没有重合部分,问最大的k为多少?输入格式第一行为一个正整数n,下面n行每行2个数字ai,bi,描述每条线段。输出格式输出文件仅包括1...

    【题解】2019 T2 公交换乘

    【题目描述】著名旅游城市 B 市为了鼓励大家采用公共交通方式出行,推出了一种地铁换乘公交车的优惠方案:1、在搭乘一次地铁后可以获得一张优惠票,有效期为 45 分钟,在有效期内可以消耗这张优惠...

    【题解】01串

    【题目描述】Fans是个ACM程序设计迷。有时侯,他表现出很强烈的逆反心理,你往东,他往西,你往南,他偏往北。这一次,不知道又是谁惹着他了,好端端的一个个01串,到了他的手里,都变成10串了。请你编个...

    【题解】使每位学生都有座位的最少移动次数

    【题目描述】一个房间里有 n 个 空闲 座位和 n 名 站着的 学生,房间用一个数轴表示。给你一个长度为 n&...