Description
Input
|
|
|
|
第一行是物品数量n和背包总容量C 第二行是n件物品的价值 第三行是n件物品的重量 |
|
|
|
|
Output
Sample Input
Sample Output
#include<iostream>
using namespace std;
#define N 100
int v[N];
int w[N];
int m[N][N];
int flag[N];
int main()
{
int n,c,i,j,max;
while(cin>>n>>c)
{
for(i=1;i<=n;i++)
cin>>v[i];
for(i=1;i<=n;i++)
cin>>w[i];
for(i=0;i<=c;i++)
flag[i]=i;//用于记录相应每一列剩下的背包容量
for(j=0;j<=c;j++)//初始化最后一行
{
if(j>=w[n])
{
m[n][j]=v[n];
flag[j]=flag[j]-w[n];
}
else
m[n][j]=0;
}
for(i=n-1;i>=1;i--)
{
for(j=0;j<=c;j++)
{
if(flag[j]>=w[i])
{
if(m[i+1][j]>(m[i+1][j]+v[i]))
m[i][j]=m[i+1][j];//第i个物体没有被加入背包
else
{
m[i][j]=m[i+1][j]+v[i];//第i个物体加入了背包
flag[j]=flag[j]-w[i];//相应地,把该列的背包所剩容量减去第i个物体的重量
}
}
else
m[i][j]=m[i+1][j];
}
}
max=m[1][0];
for(j=1;j<=c;j++)
{
if(m[1][j]>max)
max=m[1][j];
}
cout<<max<<endl;
}
return 0;
}