01背包
物品:将价格看作体积,价格乘重要度看作价值。 背包容量:总钱数
#include <iostream>
using namespace std;
const int N = 30010;
int n,m;
int v[N],w[N];
int f[N];
int main()
{
cin >> m >> n;
for(int i=1;i<=n;i++)
{
cin >> v[i] >> w[i], w[i] *= v[i];
}
for(int i=1;i<=n;i++)
for(int j =m;j>=v[i];j--)
f[j] = max(f[j],f[j-v[i]] + w[i]);
cout<<f[m]<<endl;
}