Big Event in HDU HDU - 1171
Posted kayiko
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Big Event in HDU HDU - 1171相关的知识,希望对你有一定的参考价值。
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1171
题意:给出每个物体的价值和物体的数量,如何分使得A,B所得价值最接近并且A的价值不能小于B
思路:将总和平分后,就是一道01背包题了
#include <stdio.h> #include <string.h> #include <algorithm> using namespace std; const int maxn = 1e6; int val[maxn]; int dp[maxn]; int main() { int n,i,j,a,b,l,sum; while(~scanf("%d",&n)) { if(n<=0)break; memset(val,0,sizeof(val)); memset(dp,0,sizeof(dp)); l = 0; sum = 0; for(i = 0;i<n;i++) { scanf("%d%d",&a,&b); while(b--) { val[l++] = a; sum+=a; } } for(i = 0;i<l;i++) { for(j = sum/2;j>=val[i];j--)//01背包 { dp[j] = max(dp[j],dp[j-val[i]]+val[i]); } } printf("%d %d\n",sum-dp[sum/2],dp[sum/2]); } return 0; }
以上是关于Big Event in HDU HDU - 1171的主要内容,如果未能解决你的问题,请参考以下文章
HDU-1171 Big Event in HDU (多重背包)
hdu 1171 Big Event in HDU(01背包)