首页 > 其他分享 >01背包问题之蒟蒻随记

01背包问题之蒟蒻随记

时间:2022-11-26 19:34:00浏览次数:44  
标签:件物品 int 选法 01 背包 随记

01背包的重点即是状态转移方程

让我们来一起过一遍题目:

有 N 件物品和一个容量是 V 的背包。每件物品只能使用一次。

第 i件物品的体积是 v,价值是 w。求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值最大。

请你输出最大价值。

他的状态转移方程是:
f [ i ][ j ]  =  max( f [ i - 1 ][ j ], f [ i-1 ] [ j - v [ i ] ]+ w [ i ] )

在这之中f [ i ][ j ] :表示在我们所有的选择办法的集合中,只从i个物品中选,并且总占用体积不大于j的选法的集合,

它的值是这个集合中任意一个选法的最大值.

所以我们根据这个方程直接上代码就可以了

#include <bits/stdc++.h>
using namespace std;
const int N = 1001;
    int n, m;
    int v[N], w[N];
    int f[N][N];
int main() {

    cin >> n >> m;
    for(int i = 1; i <= n; i++)
        cin >> v[i] >> w[i];
    for(int i = 1; i <= n; i++)
     {
        for(int j = 0; j <= m; j++)
        {
            f[i][j] = f[i-1][j];
            if(j>=v[i])
              f[i][j] = max(f[i][j], f[i-1][j-v[i]]+w[i]);
        }
    }

    cout << f[n][m] << endl;
 return 0;
}

 

标签:件物品,int,选法,01,背包,随记
From: https://www.cnblogs.com/ViolentForTy0917/p/16928120.html

相关文章

  • 洛谷P2015 二叉苹果树
    slojP10153.「一本通5.2例1」二叉苹果树P2015二叉苹果树题目描述有一棵苹果树,如果树枝有分叉,一定是分二叉(就是说没有只有一个儿子的结点)这棵树共有N个结点(叶子......
  • dp完全背包问题解组合问题——零钱兑换
    本题为完全背包问题,遍历容量需要顺序遍历classSolution{public:intchange(intamount,vector<int>&coins){//完全背包顺序遍历//背包容量为a......
  • 如何扩展 Mac mini 2018 内存条 All In One
    如何扩展Macmini2018内存条AllInOne升级Macmini(2018年)的内存https://support.apple.com/en-us/HT205041#onehttps://support.apple.com/zh-cn/HT205041#on......
  • 100018 求三角形任意一边已知其他两边长
    <?phpheader('Content-Type:text/html;charset=utf-8');define('ROOT',$_SERVER['DOCUMENT_ROOT']);includeROOT.'/assets/php/head.php';$tit='求三角形任意一......
  • 2022-11-26-01
    1packagecn.itsource_01lambda_function;23importjava.util.function.Function;45/**6*lambda对实例方法的使用:7*Function接口8*......
  • pwn | 铁人三项(第五赛区)_2018_rop
    pwn|铁人三项(第五赛区)_2018_ropret2libc好久没整pwn题了,ret2libc整了好久才打通==vulnerablefunction里面存在栈溢出,只开了nx保护。libc的版本是2.27再整理一......
  • 《BEGINNING RUST PROGRAMMING》---读书随记(1)
    BEGINNINGRUSTPROGRAMMINGAuthor:RicMessier如果需要电子书的小伙伴,可以留下邮箱,看到了会发送的Chpater1.GameofLife:TheBasics编写一个简单的游戏,首先是......
  • 《BEGINNING RUST PROGRAMMING》---读书随记(2)
    BEGINNINGRUSTPROGRAMMINGAuthor:RicMessier如果需要电子书的小伙伴,可以留下邮箱,看到了会发送的Chapter2ExtendedLifeUNDERSTANDINGOWNERSHIP首先需要解释R......
  • 《BEGINNING RUST PROGRAMMING》---读书随记(4)
    BEGINNINGRUSTPROGRAMMINGAuthor:RicMessier如果需要电子书的小伙伴,可以留下邮箱,看到了会发送的Chapter4Hangman虽然我们不会做任何图形界面,但我们仍然可以做......
  • 《BEGINNING RUST PROGRAMMING》---读书随记(3)
    BEGINNINGRUSTPROGRAMMINGAuthor:RicMessier如果需要电子书的小伙伴,可以留下邮箱,看到了会发送的Chapter3BuildingaLibraryREFERENCES在我们将一个多维数组......