完全背包问题(c++)

完全背包问题

当前有 N 种物品,第 i 种物品的体积是 ci​,价值是 wi​。

每种物品的数量都是无限的,可以选择任意数量放入背包。

现有容量为 V 的背包,请你放入若干物品,使总体积不超过 V,并且总价值尽可能大。

解析
虽然物品个数是无限的,但是实际上,由于背包容量有上限,每个物品最多选取的个数也是有限制的,这样可以转换成多重背包问题,进而可以转换成 01 背包问题。

可以用多重背包的思想来解决完全背包。

for (int i = 1; i <= N; i++) {
    for (int j = 0; j <= V; j++) {
        for (int k = 0; k * c[i] <= j; k++) {
            dp[i][j] = max(dp[i - 1][j - c[i] * k] + w[i] * k, dp[i][j]);
        }
    }
}

时间效率优化

我们可以注意到

dp[i][v]=max(dp[i−1][v],dp[i−1][v−ci​]+wi​,dp[i−1][v−ci​×2]+wi​×2…)

dp[i][v−ci​]=max(dp[i−1][v−ci​],dp[i−1][v−ci​×2]+wi​,dp[i−1][v−ci​×3]+wi​×2…)

也就是说,我们完全可以用 dp[i][v−ci​] 的信息去更新 dp[i][v],而不用去多此一举去枚举 k 了,转移可以直接变成如下:

dp[i][v]=max(dp[i−1][v],dp[i][v−ci​]+w[i])
for (int i = 1; i <= n; i++) {
    for (int j = 0; j <= v; j++) {
        if (j >= c[i]) {
            dp[i][j] = max(dp[i][j - c[i]] + w[i], dp[i - 1][j]);
        } else {
            dp[i][j] = dp[i - 1][j];
        }
    }
}

完整代码

 

#include <iostream>
#include <cstring>
using namespace std;

int dp[21][1010];
int w[21], c[21];

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

 

 

 

 

相关推荐

  1. 动态规划求解完全背包问题(c++实现)

    2024-05-12 17:34:07       48 阅读
  2. [C++][算法基础]完全背包问题(动态规划)

    2024-05-12 17:34:07       33 阅读
  3. 01 背包问题c++)

    2024-05-12 17:34:07       32 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-12 17:34:07       76 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-12 17:34:07       81 阅读
  3. 在Django里面运行非项目文件

    2024-05-12 17:34:07       65 阅读
  4. Python语言-面向对象

    2024-05-12 17:34:07       76 阅读

热门阅读

  1. Android App开机启动

    2024-05-12 17:34:07       34 阅读
  2. vim 查找字符串的命令

    2024-05-12 17:34:07       32 阅读
  3. 关于XDC 约束固化flash流程

    2024-05-12 17:34:07       87 阅读
  4. 学习Uni-app开发小程序Day8

    2024-05-12 17:34:07       32 阅读
  5. 基于springboot的校园社团信息管理系统源码数据库

    2024-05-12 17:34:07       31 阅读
  6. 程序分享--常见算法/编程面试题:跳跃游戏 II

    2024-05-12 17:34:07       34 阅读
  7. 【docker】容器优化:一行命令换源

    2024-05-12 17:34:07       32 阅读
  8. Vue.js介绍

    2024-05-12 17:34:07       24 阅读