#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <vector>
#include <queue>
#include <map>
#include <algorithm>
#include <string.h>
#include <iostream>
using namespace std;
#define MAXN 500005
#define INF 1e9
#define MOD 1000000007
#define LL long long
#define CLR(x) memset(x, 0, sizeof(x))
#define DCLR(x) memset(x, -1, sizeof(x))
void debug(int (*f)[20]){
printf("debug : \n");
for(int i = 1 ; i <= 5 ; i++){
for(int j = 1 ; j <= 10 ; j++){
printf("%4d",f[i][j]);
}
printf("\n");
}
printf("\n");
}
int main()
{
int n , v;
int p[20] , c[20];
int f[20][20];
CLR(f);
cin>>n>>v;
for(int i=1; i<=n; i++)
cin>>p[i];//价值
for(int i=1; i<=n; i++)
cin>>c[i];//体积
for(int i=1; i<=n; i++)
f[i][0]=0;
for(int i=1; i<=n; i++)
{
for(int j=1; j<=v; j++)
if(j>=c[i] ) f[i][j]=max(f[i-1][j-c[i]]+p[i],f[i-1][j]);
else f[i][j] = f[i-1][j];
debug(f);
}
return 0;
}
/*
5 10
6 3 5 4 6
2 2 6 5 4
*/
看了好多博客其实还是并不是很懂状态转移这个含义,目前只能依葫芦画瓢了呀。