经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C++ » 查看文章
01背包、完全背包模板
来源:cnblogs  作者:Interest_d  时间:2018/11/29 9:27:50  对本文有异议
  1. 1 #include<iostream>
  2. 2 #include<cstdio>
  3. 3 using namespace std;
  4. 4 const int maxn=510,maxw=510;
  5. 5 int w[maxn],v[maxw],a[maxw];
  6. 6 int main(){
  7. 7 int n,W;
  8. 9 cin>>n>>W;
  9. 10 for(int i=1;i<=n;i++)
  10. 11 cin>>w[i];
  11. 12 for(int i=1;i<=n;i++)
  12. 13 cin>>v[i];
  13. 14 for(int i=1;i<=n;i++)
  14. 15 for(int j=W;j>=w[i];j--)//j>=0
  15. 16 if(j>=w[i]) a[j]=max(a[j],a[j-w[i]]+v[i]);
  16. 17 cout<<a[W]<<endl;
  17. 18 fclose(stdin);
  18. 19 return 0;
  19. 20 }
    输入:4 8

2 3 4 5
3 4 5 6

输出:

10



  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int maxn=510, maxw=510;
  4. int n,W,dp[maxw],w[maxn],v[maxn];
  5. int main(){
  6. cin>>n>>W;
  7. for(int i=1;i<=n;i++)
  8. cin>>w[i];
  9. for(int i=1;i<=n;i++)
  10. cin>>v[i];
  11. for(int i=1;i<=n;i++)
  12. for(int j=w[i];j<=W;j++)//j可以从0开始,也可以从w[i]开始
  13. if(j>=w[i]) dp[j]=max(dp[j],dp[j-w[i]]+v[i]);
  14. cout<<dp[W];
  15. return 0;
  16. }

    输入

4 10
2 3 4 7
1 3 5 9

输出

12 

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号