博客
关于我
AcWing 9. 分组背包问题(动态规划dp)
阅读量:351 次
发布时间:2019-03-04

本文共 1916 字,大约阅读时间需要 6 分钟。

为了解决这个问题,我们需要找到一种方法来选择背包中的物品,使得总体积不超过背包容量,并且总价值最大。这个问题类似于0-1背包问题,但每个物品来自不同的组,每组只能选择一个物品。

方法思路

  • 问题分析:每个组中的物品只能选择一个,因此我们可以将每个物品看作一个独立的物品进行处理。
  • 动态规划:使用动态规划来解决这个问题。我们创建一个数组 dp,其中 dp[j] 表示容量为 j 时的最大价值。
  • 排序物品:为了优化处理,先将物品按体积从小到大排序,这样可以更高效地更新动态规划数组。
  • 处理每个物品:对于每个物品,检查其体积是否超过背包容量,如果不超过,则更新动态规划数组。
  • 解决代码

    import java.io.*;import java.util.*;class Main {    static int[] dp = new int[1001];    static int n = 0, m = 0;    static List
    items = new ArrayList<>(); public static void main(String[] args) throws Exception { BufferedReader buf = new BufferedReader(new InputStreamReader(System.in)); String[] params = buf.readLine().split(" "); n = Integer.parseInt(params[0]); m = Integer.parseInt(params[1]); for (int i = 1; i <= n; ++i) { int cnt = Integer.valueOf(buf.readLine()); for (int j = 1; j <= cnt; ++j) { String[] info = buf.readLine().split(" "); int a = Integer.valueOf(info[0]); int b = Integer.valueOf(info[1]); items.add(new int[]{a, b}); } } // 排序物品,按体积升序 Collections.sort(items, new Comparator
    () { public int compare(int[] a, int[] b) { return Integer.compare(a[0], b[0]); } }); // 初始化动态规划数组 Arrays.fill(dp, 0); for (int[] item : items) { int v = item[0]; int w = item[1]; if (v > m) continue; for (int j = m; j >= v; --j) { if (dp[j - v] + w > dp[j]) { dp[j] = dp[j - v] + w; } } } System.out.println(dp[m]); }}

    代码解释

  • 读取输入:首先读取背包容量 V 和物品组数 N,然后读取每个组的物品数据。
  • 排序物品:将所有物品按体积从小到大排序,以优化动态规划的处理。
  • 初始化动态规划数组dp 数组初始化为全0,表示初始时背包为空。
  • 处理每个物品:对于每个物品,检查其体积是否超过背包容量,如果不超过,则从后向前更新 dp 数组,确保每个物品只被选一次。
  • 输出结果:最后输出背包容量为 V 时的最大价值。
  • 这种方法确保了每个物品只被处理一次,并且通过动态规划高效地更新背包状态,能够在合理时间内解决问题。

    转载地址:http://zyre.baihongyu.com/

    你可能感兴趣的文章
    Openlayers高级交互(6/20):绘制某点,判断它是否在一个电子围栏内
    查看>>
    Openlayers高级交互(7/20):点击某点弹出窗口,自动播放视频
    查看>>
    Openlayers高级交互(8/20):选取feature,平移feature
    查看>>
    Openlayers高级交互(9/20):编辑图形(放缩、平移、变形、旋转),停止编辑
    查看>>
    Openlayers:DMS-DD坐标形式互相转换
    查看>>
    openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
    查看>>
    OpenLDAP(2.4.3x)服务器搭建及配置说明
    查看>>
    OpenLDAP编译安装及配置
    查看>>
    Openmax IL (二)Android多媒体编解码Component
    查看>>
    OpenMCU(一):STM32F407 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(三):STM32F103 FreeRTOS移植
    查看>>
    OpenMCU(二):GD32E23xx FreeRTOS移植
    查看>>
    OpenMCU(五):STM32F103时钟树初始化分析
    查看>>
    OpenMCU(四):STM32F103启动汇编代码分析
    查看>>
    OpenMetadata 命令执行漏洞复现(CVE-2024-28255)
    查看>>
    OpenMMLab | AI玩家已上线!和InternLM解锁“谁是卧底”新玩法
    查看>>
    OpenMMLab | S4模型详解:应对长序列建模的有效方法
    查看>>
    OpenMMLab | 【全网首发】Llama 3 微调项目实践与教程(XTuner 版)
    查看>>
    OpenMMLab | 不是吧?这么好用的开源标注工具,竟然还有人不知道…
    查看>>