码迷,mamicode.com
首页 > 其他好文 > 详细

HDU 1171 Big Event in HDU(01背包)

时间:2017-12-19 01:22:22      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:mem   mes   log   gpo   ble   pac   i++   return   clu   

题目链接

题意:给出n个物品的价值v,每个物品有m个,设总价值为sum,求a,b。a+b=sum,且a尽可能接近b,a>=b。

题解:01背包。

#include <bits/stdc++.h>
using namespace std;
int data[5050],dp[125050],n,v,m;
int main()
{
    while(scanf("%d",&n)&&n>0)
    {
        memset(dp,0,sizeof(dp));
        int sum=0,cnt=0;
        for(int i=0;i<n;i++)
        {
            scanf("%d%d",&v,&m);
            sum+=v*m;
            while(m--) data[cnt++]=v;
        }
        int k=sum/2;
        for(int i=0;i<cnt;i++)//注意不是n
        for(int j=k;j>=data[i];j--)
        dp[j]=max(dp[j],dp[j-data[i]]+data[i]);
        printf("%d %d\n",sum-dp[k],dp[k]);
    }
    return 0;
}

 

HDU 1171 Big Event in HDU(01背包)

标签:mem   mes   log   gpo   ble   pac   i++   return   clu   

原文地址:http://www.cnblogs.com/Ritchie/p/8059160.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!