hdu-1059(多重背包+二进制优化)

时间:2023-02-08 02:21:45

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1059

题意:输入6个数,每个数ni代表价值为i的物品有ni个。求如果这些物品能均分给两个人,每个人获得的物品的总价值

相同,就输出“Can be divided.”,否则输出“Can't be divided.”;具体格式见输出格式。

思路:本来想用dfs做的,后来发现时间超限了,其实可以用多重背包来做,

每个物品的数量有限,找出是否存在几个物品的价值与物品总价值的一半相同。

参考文章:https://blog.csdn.net/aaaaacmer/article/details/48543575

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int dp[],a[],sum;
void f(int cost,int num)
{
int i;
if(cost*num>=sum)
{
for(i=cost;i<=sum;i++)
dp[i]=max(dp[i],dp[i-cost]+cost);
return ;
}
int k=;
while(k<num)
{
for(i=sum;i>=k*cost;i--)
dp[i]=max(dp[i],dp[i-cost*k]+cost*k);
num-=k;
k*=;
}
for(i=sum;i>=num*cost;i--)
dp[i]=max(dp[i],dp[i-cost*num]+cost*num);
}
int main(void)
{
int pt=,i,j;
while(cin>>a[]>>a[]>>a[]>>a[]>>a[]>>a[])
{
if(!a[]&&!a[]&&!a[]&&!a[]&&!a[]&&!a[]) break;
sum=;
for(i=;i<=;i++) sum+=a[i]*i;
printf("Collection #%d:\n",pt++);
if(sum%)
{
printf("Can't be divided.\n\n");
continue;
}
sum/=;
memset(dp,,sizeof(dp));
for(i=;i<=;i++) f(i,a[i]);
if(dp[sum]==sum) printf("Can be divided.\n\n");
else printf("Can't be divided.\n\n");
}
return ;
}

hdu-1059(多重背包+二进制优化)的更多相关文章

  1. D - D 分糖果HDU - 1059&lpar;完全背包&plus;二进制优化&rpar;

    有两个小朋友想要平分一大堆糖果,但他们不知道如何平分需要你的帮助,由于没有spj我们只需回答能否平分即可. 糖果大小有6种分别是1.2.3.4.5.6,每种若干颗,现在需要知道能不能将这些糖果分成等额 ...

  2. hdu 1171 Big Event in HDU(多重背包&plus;二进制优化)

    题目链接:hdu1171 思路:将多重背包转为成完全背包和01背包问题,转化为01背包是用二进制思想,即件数amount用分解成若干个件数的集合,这里面数字可以组合成任意小于等于amount的件数 比 ...

  3. hdu 2191 &lpar;多重背包&plus;二进制优化&rpar;

    Problem Description 急!灾区的食物依然短缺!为了挽救灾区同胞的生命,心系灾区同胞的你准备自己采购一些粮食支援灾区,现在假设你一共有资金n元,而市场有m种大米,每种大米都是袋装产品, ...

  4. hdu 2191 &lpar;多重背包二进制优化)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=2191 实现代码: #include<bits/stdc++.h> using namespac ...

  5. hdu 2844 多重背包二进制优化

    //http://www.cnblogs.com/devil-91/archive/2012/05/16/2502710.html #include<stdio.h> #define N ...

  6. HDOJ&lpar;HDU&rpar;&period;1059 Dividing&lpar;DP 多重背包&plus;二进制优化&rpar;

    HDOJ(HDU).1059 Dividing(DP 多重背包+二进制优化) 题意分析 给出一系列的石头的数量,然后问石头能否被平分成为价值相等的2份.首先可以确定的是如果石头的价值总和为奇数的话,那 ...

  7. HDU 3591 &lpar;完全背包&plus;二进制优化的多重背包)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3591 The trouble of Xiaoqian Time Limit: 2000/1000 M ...

  8. HDOJ&lpar;HDU&rpar;&period;2844 Coins &lpar;DP 多重背包&plus;二进制优化&rpar;

    HDOJ(HDU).2844 Coins (DP 多重背包+二进制优化) 题意分析 先把每种硬币按照二进制拆分好,然后做01背包即可.需要注意的是本题只需要求解可以凑出几种金钱的价格,而不需要输出种数 ...

  9. HDOJ&lpar;HDU&rpar;&period;2191&period; 悼念512汶川大地震遇难同胞&horbar;&horbar;珍惜现在,感恩生活 &lpar;DP 多重背包&plus;二进制优化&rpar;

    HDOJ(HDU).2191. 悼念512汶川大地震遇难同胞――珍惜现在,感恩生活 (DP 多重背包+二进制优化) 题意分析 首先C表示测试数据的组数,然后给出经费的金额和大米的种类.接着是每袋大米的 ...

  10. hdu1059 dp&lpar;多重背包二进制优化&rpar;

    hdu1059 题意,现在有价值为1.2.3.4.5.6的石头若干块,块数已知,问能否将这些石头分成两堆,且两堆价值相等. 很显然,愚蠢的我一开始并想不到什么多重背包二进制优化```因为我连听都没有听 ...

随机推荐

  1. C&num; MVC 5 - 生命周期(应用程序生命周期&amp&semi;请求生命周期)

    本文是根据网上的文章总结的. 1.介绍 本文讨论ASP.Net MVC框架MVC的请求生命周期. MVC有两个生命周期,一为应用程序生命周期,二为请求生命周期. 2.应用程序生命周期 应用程序生命周期 ...

  2. 1&period;Java网络编程之概述

    黑马程序员_毕向东_Java基础视频教程第23天-01-网络编程(概述)学习笔记 网络通讯三要素: 1.IP地址 I.网络中设备的标识  II.不易记忆,可用主机名 www 万维网组织,baidu主机 ...

  3. Centos6&period;5安装和使用docker

    rpm -ivh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm yum install docke ...

  4. Visual Studio 2008破解激活升级方法

    声明:本文中涉及到的序列号及更新方法均来自互联网,请支持正版. 微软为业余爱好者.热衷者和学生提供了免费版——Express Edition (轻型.易学.易用的开发工具). 如不想支付任何费用,建议 ...

  5. 在浏览器中将表格导入到本地的EXCEL文件,注意控制内存

    if ($export_flag == 1) { $rr = $this->mdl->test($test); header("Content-Type: application ...

  6. 论文笔记之:Decoupled Deep Neural Network for Semi-supervised Semantic Segmentation

    Decoupled Deep Neural Network for Semi-supervised Semantic Segmentation xx

  7. SpringMVC&colon;com&period;mysql&period;jdbc&period;exceptions&period;MySQLSyntaxErrorException&colon; You have an error in your SQL syntax&semi;

    今天用SpringMVC做修改添加操作,之前的操作都实现了添加修改,但始终报com.mysql.jdbc.exceptions.MySQLSyntaxErrorException: You have ...

  8. unity3d应用内分享(微信、微博等)的实现

    问题:如何在unity3d的游戏中实现分享功能,如图 思路: 1.分享功能的实现方式有多种,较方便快捷的一种是直接调用android的API来调出系统的分享界面 2.unity3d里面调用androi ...

  9. JSP内置对象--4种属性范围 &lpar;pageContext&comma;request&comma;session&comma;application&rpar;

    pageContext: javax.servlet.jsp.JspContext抽象类的父类JspContext 中有以下方法. request:javax.servlet.http.的接口Http ...

  10. Linux内核架构与底层--读书笔记

    linux中管道符"|"的作用 命令格式:命令A|命令B,即命令1的正确输出作为命令B的操作对象(下图应用别人的图片) 1. 例如: ps aux | grep "tes ...