本文共 1702 字,大约阅读时间需要 5 分钟。
#include#include #include using namespace std;const int N = 1010;int f[N][N] , v[N] , w[N];int n , m;int main(){ scanf("%d%d" , &n , &m ); for(int i = 1 ; i <= n ; i ++ ) //读入每个物品的价值和重量 scanf("%d%d" , &v[i] , &w[i] ); //本来要将f[0][0]初始化成0的,但由于是在main函数外面定义,所以直接省略 //利用dp进行解答 for( int i = 1 ; i <= n ; i++ ) { for( int j = 1 ; j <= m; j++ ) { f[i][j] = f[i - 1][j];//这是考虑了没加第i个物品的情况 if(j >= v[i] )//这是考虑了第i个物品的情况 f[i][j] = max( f[i][j] , f[i - 1][j - v[i] ] + w[i] ); } } int res = 0; for(int i = 1 ; i <= m ; i++ ) res = max( res , f[n][i] ); cout<< res << endl;}
#include#include #include using namespace std;const int N = 1010;int f[N] , v[N] , w[N];int n , m;int main(){ scanf("%d%d" , &n , &m ); for(int i = 1 ; i <= n ; i ++ ) //读入每个物品的价值和重量 scanf("%d%d" , &v[i] , &w[i] ); //本来要将f[0][0]初始化成0的,但由于是在main函数外面定义,所以直接省略 //利用dp进行解答 for( int i = 1 ; i <= n ; i++ ) { for( int j = m ; j >= v[i] ; j-- ) //这里优化成一位数组,核心就在于怎么控制f[j - v[i] ]取到的是上一层的数 //即保证f[j - v[i] ] 取到 f[i - 1][j - v[i] ],由于j从大到小,所以下一轮 //的j - v[i] > j - 1 - v[i] ,因此可以保证自身不变 f[j] = max( f[j] , f[j - v[i] ] + w[i] ); } cout<< f[m] << endl;}