#include<stdio.h>
#include<stdlib.h>
int f[20][300];
int *v;
int *w;
int *res;
void package(int *w,int *v,int n,int c)
{
int i,j;
for(i=1;i<=n;i++){
f[i][0] = 0;
}
for(j=1;j<=c;j++){
f[0][j] = 0;
}
for(i=1;i<=n;i++){
for(j=1;j<=c;j++){
if(w[i] <= j && f[i-1][j-w[i]] + v[i] > f[i-1][j]){
f[i][j] = f[i-1][j-w[i]] + v[i];
}else{
f[i][j] = f[i-1][j];
}
}
}
printf("最大价值: %d \n",f[n][c]);
}
void result(int n,int c,int *res,int *v,int *w)
{
int i,j;
j = c;
for(i=n;i>=1;i--){
if(f[i][j] != f[i-1][j]){
res[i] = 1;
j = j - w[i];
}
}
}
int main()
{
int c,n;
printf("请输入物品个数n和背包容量c:");
scanf("%d %d",&n,&c);
v = (int*)malloc((n+1)*sizeof(int));
w = (int*)malloc((n+1)*sizeof(int));
res = (int*)malloc((n+1)*sizeof(int));
v[0] = 0;
w[0] = 0;
printf("请输入%d组物品的重量和价值:\n",n);
for(int o = 0;o<=n;o++){
if(o!=0){
scanf("%d %d",&w[o],&v[o]);
}
res[o] = 0;
}
int i,j;
package(w,v,n,c);
for(i=0;i<=n;i++)
{
for(j=0;j<=c;j++){
printf("%3d ",f[i][j]);
}
printf("\n");
}
result(n,c,res,v,w);
printf("放入背包的物品为: \n");
for(i=1;i<=n;i++){
if(res[i] == 1){
printf("%d ",i);
}
}
free(w);
free(v);
free(res);
return 0;
}