POJ 3624 0-1背包问题 动态规划

第一道背包问题,0-1背包,参考网上一位大牛写的做的。状态方程:dp[i][w] = max{dp[i-1][w], dp[i-1][w-obj[i].wei] + obj[i].val]},但这样会超内存,需要一个空间复杂度的优化将dp改为一维,这招看来以后得常用,具体见转载的《背包九讲》。

明天好好读读《背包九讲》,在多做几道dp变形题,练习在于精不在多。

#include <iostream> using namespace std; const int mMax = 3500;//待选物品个数 const int nMax = 14000;//最大容量 struct{ int wei,val; }node[mMax]; int main(){ int n,m,i,w,dp[nMax]; cin>>n>>m;//n为物品个数,m为最大容量 for (i = 1;i <= n;i++) cin>>node[i].wei>>node[i].val; memset(dp,0,(m+1) * sizeof(int)); for (i = 1;i <= n;i++) for (w = m;w >= node[i].wei;w--)//从后向前dp,前面的数会影响后面的 if (dp[w] < dp[w - node[i].wei] + node[i].val) dp[w] = dp[w - node[i].wei] + node[i].val; cout << dp[m]<<endl; return 0; }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值