完全背包问题

问题描述:
有N种物品和一个容量是V的背包,每种物品都有无限件可用。
第i种物品的体积是vi,价值是wi。
求解将哪些物品装入背包,可使这些物品的总体积不超过背包容量,且总价值最大。
输出最大价值。
输入:
第一行两个整数,N,V,用空格隔开,分别表示物品种数和背包容积。
接下来有N行,每行两个整数vi,wi,用空格隔开,分别表示第i种物品的体积和价值。
输出:
输出一个整数,表示最大价值。

 //完全背包问题/*f[i]表示总体积是i的情况下,最大价值是多少

result=max(f[0.....m])
for(int i=0;i<n;i++)
{
//for(int j=m;j>=v[i];j--)
//  f[j]=max(f[j],f[j-v[i]]+w[i]);//从大到小枚举是为了实现二维中的i转移至i-1状态
  for(int j=m;j>=v[i];j--)
  for(int k=0;k*v[i]<=j;k++)
    f[j]=max(f[j],f[j-k*v[i]]+k*w[i]); 
}*/
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=1010;
int n,m;
int f[N];
int main()
{
cin>>n>>m;
for(int i=0;i<n;i++)
{int v,w;
cin>>v>>w;
for(int j=v;j<=m;j++)
f[j]=max(f[j],f[j-v]+w);
}//01背包是从大到小枚举
//完全背包是从小到大枚举  循环体积 
//若题目说体积恰好用了m,问最大价值是多少 则将0初始化为0,其他的初始化为负无穷 若问的不超过m,则将0和0以外都初始化为0,定为全局区域,全局区域在堆区,系统自动将其初始化为0
cout<<f[m]<<endl; return 0; }
原文地址:https://www.cnblogs.com/hrlsm/p/12822831.html