状态定义:
f[i][j]
表示考虑前 i 个物品,总重量不超过 j 的情况下最大的价值
集合划分:
可以根据选 i 这个物品或者不选 i 这个物品进行划分
状态计算:
f[i][j] = max(f[i-1][j-w[i]] + v[i], f[i-1][j])
不优化空间
#include <iostream>
#include <cstring>
#include <algorithm>
using namespace std;
const int N = 1010;
int n, m; // n是物品的总数, m是背包的总体积
int f[N][N]; // (已放入的物品总数, 已使用的总体积) 保存的是总价值
int main()
{
cin >> n >> m;
for (int i = 1; i <= n; i ++)
{
int v, w; //当前物体的体积和价值
cin >> v >> w;
// 枚举所有状态(体积)
for (int j = 0; j <= m; j ++)
{
// 不选择物品i
f[i][j] = f[i - 1][j];
// 选择物品i(要求当前容量放的下)
if (j >= v)
f[i][j] = max(f[i][j], f[i - 1][j - v] + w);
}
}
cout << f[n][m] << endl;
return 0;
}
优化空间
#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 = 1; i <= n; i ++ )
{
int v, w;
cin >> v >> w;
for (int j = m; j >= v; j -- )
f[j] = max(f[j], f[j - v] + w);
}
cout << f[m] << endl;
return 0;
}