赞
踩
因为每个物体,都有装与不装两种选择,所以我们得到状态转移方程:
f[j]=max(f[j],f[j-w[i]]+w[i]);
f[j] 为:当总容量为 j 时,不放第 i 件物品,所能装的最大体积。
f[j-w[i]]+w[i] 为:当总容量为 j 时,放了第 i 件物品后,所能装的最大体积。(即 j减去第 i 件物品体积 的容量能装的最大体积+第 i 件物品的体积。w[i] 为第 i 件物品体积)
#include<iostream>
#include<cstdio>
using namespace std;
int f[20005],w[35];
int main()
{
int v,n;
cin>>v>>n;
for(int i=1;i<=n;i++)cin>>w[i];
for(int i=1;i<=n;i++)
for(int j=v;j>=w[i];j--)
f[j]=max(f[j],f[j-w[i]]+w[i]);
cout<<v-f[v];
return 0;
}
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。