首页 > 代码库 > hdu2191(完全背包)
hdu2191(完全背包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2191
完全背包:
1 #include <iostream> 2 #include<algorithm> 3 #include<cstring> 4 using namespace std; 5 int t,n,m; 6 int v[1110],w[1110],num[1110]; 7 int dp[1110]; 8 int main() 9 { 10 cin>>t; 11 while(t--) 12 { 13 int ans=0; 14 cin>>n>>m; 15 for(int i=0;i<m;i++) 16 cin>>v[i]>>w[i]>>num[i]; 17 memset(dp,0,sizeof(dp)); 18 for(int i=0;i<m;i++) 19 { 20 int nu=num[i]; 21 for(int k=1;nu>0;k*=2) //二进制划分 22 { 23 int tmp=min(k,nu); 24 for(int j=n;j>=tmp*v[i];j--) 25 dp[j]=max(dp[j],dp[j-tmp*v[i]]+tmp*w[i]); 26 nu-=tmp; 27 } 28 } 29 for(int i=0;i<=n;i++) 30 ans=max(ans,dp[i]); 31 cout<<ans<<endl; 32 } 33 }
hdu2191(完全背包)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。