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

【题解】完全背包问题

亿万年的星光2年前 (2023-06-10)题解目录1538

【题目描述】

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

【输入描述】

第一行:两个整数,MM(背包容量,M≤200)和NN(物品数量,N≤30N≤30);

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

【输出描述】

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

【样例输入】

10 4 
2 1 
3 3
4 5 
7 9

【样例输出】

12

【题目分析】

1. 状态定义

集合:放入背包的物品方案

限制:选择物品的范围,背包大小

属性:价值

条件:最大

统计量:价值

状态定义:dp[i][j]:在前i个物品中选择物品放入大小为j的背包能获得的最大价值。

初始状态:前0个物品放入大小为j的背包,价值为0。所以dp[0][j] = 0。


2. 状态转移方程

集合:在前i个物品中选择物品放入大小为j的背包的所有方案。

分割集合:是否选择第i物品放入背包


子集1:如果不选择第i物品,那么前i个物品中选择物品放入大小为j的背包,就是在前i-1个物品中选择物品放入大小为j的背包。能获得的最大价值为dp[i][j] = dp[i-1][j]。

子集2:如果选择第i物品,相当于先选了一个第i物品,价值是c[i]。接下来还需要在前i个物品中选择物品放入大小为j-w[i]的背包

。能获得的最大价值为dp[i][j] = dp[i][j-w[i]] + c[i]

以上两种情况求最大值


【参考答案】:二维数组

#include<bits/stdc++.h>
using namespace std;
#define N 35
#define M 205
int m, n, dp[N][M], w[N], c[N];//dp[i][j]:在前i个物品中选择物品放入大小为j的背包能获得的最大价值
int main()
{
    cin >> m >> n;//m:背包容量 n:物品数 
    for(int i = 1; i <= n; ++i)
        cin >> w[i] >> c[i];//w[i]:第i物品的重量 c[i]:第i物品的价值 
    for(int i = 1; i <= n; ++i)
        for(int j = 0; j <= m; ++j)
        {
            if(j >= w[i])
                dp[i][j] = max(dp[i-1][j], dp[i][j-w[i]]+c[i]);
            else
                dp[i][j] = dp[i-1][j];
        }
    cout << "max=" << dp[n][m];
    return 0;
}

【参考答案】:一维数组

#include<bits/stdc++.h>
using namespace std;
#define N 35
#define M 205
int m, n, dp[M], w[N], c[N];//dp[i][j]:在前i个物品中选择物品放入大小为j的背包能获得的最大价值
int main()
{
    cin >> m >> n;//m:背包容量 n:物品数 
    for(int i = 1; i <= n; ++i)
        cin >> w[i] >> c[i];//w[i]:第i物品的重量 c[i]:第i物品的价值 
    for(int i = 1; i <= n; ++i)
        for(int j = w[i]; j <= m; ++j)
            dp[j] = max(dp[j], dp[j-w[i]]+c[i]);
    cout << "max=" << dp[m];
    return 0;
}


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

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

分享给朋友:

相关文章

迷宫

【题目描述】一天Extense在森林里探险的时候不小心走入了一个迷宫,迷宫可以看成是由n * n的格点组成,每个格点只有2种状态,.和#,前者表示可以通行后者表示不能通行。同时当Extense处在某个...

公路(road)

公路(road)

【题目描述】小苞准备开着车沿着公路自驾。公路上一共有n个站点,编号为从1 到n。其中站点i与站点i+1 的距离为vi公里。公路上每个站点都可以加油,编号为i 的站点一升油的价格为a...

【题解】电池的寿命

【题目描述】小S新买了一个掌上游戏机,这个游戏机由两节5号电池供电。为了保证能够长时间玩游戏,他买了很多5号电池,这些电池的生产商不同,质量也有差异,因而使用寿命也有所不同,有的能使用5个小时,有的可...

【题解】画百钱买百鸡

【题目描述】鸡翁一,值钱五,鸡母一,值钱三,鸡雏三,值钱一,百钱买百鸡。问鸡翁、鸡母、鸡雏各几何?#include<iostream> using namespace ...

【题解】真分数(2019青岛市程序设计竞赛)

【描述】真分数,指的是分子比分母小的分数,真分数的分数值小于1。给出n个正整数,任取两个数分别作为分子和分母组成真分数。求能组成多少不同值的真分数。【输入】第一行是一个正整数n。第二行是n个不同的正整...

【题解】马拦过河卒

【题解】马拦过河卒

【题目描述】棋盘上A点有一个过河卒,需要走到目标B点。卒行走的规则:可以向下、或者向右。同时在棋盘上C点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点。因此称之为“马拦过河卒”。...