01背包、完全背包模板
2018-11-28 08:50:50来源:博客园 阅读 ()
1 #include<iostream> 2 #include<cstdio> 3 using namespace std; 4 const int maxn=510,maxw=510; 5 int w[maxn],v[maxw],a[maxw]; 6 int main(){ 7 int n,W; 9 cin>>n>>W; 10 for(int i=1;i<=n;i++) 11 cin>>w[i]; 12 for(int i=1;i<=n;i++) 13 cin>>v[i]; 14 for(int i=1;i<=n;i++) 15 for(int j=W;j>=w[i];j--)//j>=0 16 if(j>=w[i]) a[j]=max(a[j],a[j-w[i]]+v[i]); 17 cout<<a[W]<<endl; 18 fclose(stdin); 19 return 0; 20 }
输入:4 8
2 3 4 5
3 4 5 6
输出:
10
#include<bits/stdc++.h> using namespace std; const int maxn=510, maxw=510; int n,W,dp[maxw],w[maxn],v[maxn]; int main(){ cin>>n>>W; for(int i=1;i<=n;i++) cin>>w[i]; for(int i=1;i<=n;i++) cin>>v[i]; for(int i=1;i<=n;i++) for(int j=w[i];j<=W;j++)//j可以从0开始,也可以从w[i]开始 if(j>=w[i]) dp[j]=max(dp[j],dp[j-w[i]]+v[i]); cout<<dp[W]; return 0; }
输入
4 10
2 3 4 7
1 3 5 9
输出
12
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:VS2015中不同开发环境设置转换(C#->C++等)
下一篇:C++的特点
- C++冒泡排序 (基于函数模板实现) 2020-05-31
- C++ 模板类vector 2020-05-31
- C++ 模板类array 2020-05-31
- C++ 模板类vector 2020-05-30
- 单调队列模板【附例题】 2020-05-05
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash