poj 3624 经典01 dp

第一道入门dp,看了好多大神的评论才理解了一些思想。

 

用的是一维数组进行的模拟

#include<iostream>
//#include<fstream>
using namespace std;

int weight[12881]= {0},value[12881]={0},dp[12881]={0};
int max(int a,int b)
{
return a>b?a:b;
}
int main()
{
//ifstream cin("in.txt");
int n,m,j;
cin>>n>>m;
for(int i = 0; i < n; i ++)
cin>>weight[i]>>value[i];
for(int i = 0; i < n; i ++)
{
for( j = m; j >= weight[i]; j --)
dp[j] = max(dp[j],(dp[j-weight[i]]+value[i]));//这一步应该仔细想想,实在不理解可以在编译器上调试,看看运行进程

}
cout<<dp[m]<<endl;
}

posted on 2012-09-24 17:29  元点之始  阅读(188)  评论(0编辑  收藏  举报

导航