zb的生日

时间限制:3000 ms  |  内存限制:65535 KB
难度:2
 
描述
今天是阴历七月初五,acm队员zb的生日。zb正在和C小加、never在武汉集训。他想给这两位兄弟买点什么庆祝生日,经过调查,zb发现C小加和never都很喜欢吃西瓜,而且一吃就是一堆的那种,zb立刻下定决心买了一堆西瓜。当他准备把西瓜送给C小加和never的时候,遇到了一个难题,never和C小加不在一块住,只能把西瓜分成两堆给他们,为了对每个人都公平,他想让两堆的重量之差最小。每个西瓜的重量已知,你能帮帮他么?
 
输入
多组测试数据(<=1500)。数据以EOF结尾
第一行输入西瓜数量N (1 ≤ N ≤ 20)
第二行有N个数,W1, …, Wn (1 ≤ Wi ≤ 10000)分别代表每个西瓜的重量
输出
输出分成两堆后的质量差
样例输入
  1. 5
  2. 5 8 13 27 14
样例输出
  1. 3
  2.  
  3. 解题思路:这道题可以用01背包的思想来做,dp[j]表示容量为j时的的最大重量。首先将所有西瓜重量的一半作为背包容量,因为分为两堆时,肯定有一堆重量是>=(sum/2)那么我们就可以让尽量大的西瓜重量来填sum/2这个背包。如果分成的两堆重量为ab那么|a-b|=|a-(sum-a)|=|2*a-sum|。所以答案就是|2*dp[v]-sum|。
  4.  
  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int maxn=210000;
  4. int a[30],dp[maxn];
  5. int fas(int x){
  6. return x>0?x:-x;
  7. }
  8. int main(){
  9. int n,i,j,k,m,cnt,t,v,sum;
  10. while(scanf("%d",&n)!=EOF){
  11. memset(dp,0,sizeof(dp));
  12. sum=0;
  13. for(i=1;i<=n;i++){
  14. scanf("%d",&a[i]);
  15. sum+=a[i];
  16. }
  17. v=sum/2;
  18. for(i=1;i<=n;i++){
  19. for(j=v;j>=a[i];j--){
  20. dp[j]=dp[j]>(dp[j-a[i]]+a[i])?dp[j]:(dp[j-a[i]]+a[i]);
  21. }
  22. }
  23. printf("%d\n",fas(2*dp[v]-sum));
  24. }
  25. return 0;
  26. }

 

还有一种很巧妙的方法。也是01背包的思想,背包总容量也是sum/2,只是这个dp[i]表示的是背包内的重量为i的西瓜组合是否可以能可以形成。

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. const int maxn=200100;
  4. int a[21];
  5. bool dp[maxn];
  6. int fas(int x){
  7. return x>0?x:-x;
  8. }
  9. int main(){
  10. int n,i,j,k,m,cnt,t,v,sum;
  11. while(scanf("%d",&n)!=EOF){
  12. memset(dp,0,sizeof(dp));
  13. sum=0;
  14. for(i=1;i<=n;i++){
  15. scanf("%d",&a[i]);
  16. sum+=a[i];
  17. }
  18. v=sum/2;
  19. dp[0]=true;
  20. for(i=1;i<=n;i++){
  21. for(j=v;j>=a[i];j--){
  22. if(dp[j-a[i]])
  23. dp[j]=true;
  24. }
  25. }
  26. for(i=v;i>=0&&(!dp[i]);i--);
  27. printf("%d\n",fas(2*i-sum));
  28. }
  29. return 0;
  30. }

  

nyoj 325——zb的生日——————【dp】的更多相关文章

  1. nyoj 0325 zb的生日(dp)

    nyoj 0325 zb的生日 zb的生日 时间限制:3000 ms  |  内存限制:65535 KB 难度:2 描述 今天是阴历七月初五,acm队员zb的生日.zb正在和C小加.never在武汉集 ...

  2. nyoj 325 zb的生日

    01背包 zb的生日 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 今天是阴历七月初五,acm队员zb的生日.zb正在和C小加.never在武汉集训.他想给这两位兄 ...

  3. nyoj 325 zb的生日(dfs)

    描述今天是阴历七月初五,acm队员zb的生日.zb正在和C小加.never在武汉集训.他想给这两位兄弟买点什么庆祝生日,经过调查,zb发现C小加和never都很喜欢吃西瓜,而且一吃就是一堆的那种,zb ...

  4. NYOJ之题目325 zb的生日

    -------------------------------------- 刷一辈子水题... AC代码: import java.util.Scanner; public class Main { ...

  5. NY 325 zb的生日

    假设所有西瓜重 Asum,所求的是用 Asum / 2 的背包装,最多装下多少. 刚开始用贪心作的,WA.后来用01背包,结果TLE,数据太大.原来用的是深搜! dfs(int sum, int i) ...

  6. zb的生日

    http://acm.nyist.net/JudgeOnline/problem.php?pid=325 zb的生日 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 ...

  7. nyoj zb的生日

    zb的生日 时间限制:3000 ms  |  内存限制:65535 KB 难度:2 描述 今天是阴历七月初五,acm队员zb的生日.zb正在和C小加.never在武汉集训.他想给这两位兄弟买点什么庆祝 ...

  8. nyoj zb的生日【背包型DFS/选or不选】

    zb的生日 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 今天是阴历七月初五,acm队员zb的生日.zb正在和C小加.never在武汉集训.他想给这两位兄弟买点什么 ...

  9. ACM zb的生日

    zb的生日 时间限制:3000 ms  |  内存限制:65535 KB 难度:2   描述 今天是阴历七月初五,acm队员zb的生日.zb正在和C小加.never在武汉集训.他想给这两位兄弟买点什么 ...

随机推荐

  1. (二)RabbitMQ使用笔记

    1.RabbitMQ简介 RabbitMQ是流行的开源消息队列系统,用erlang语言开发.RabbitMQ是AMQP(高级消息队列协议)的标准实现. 官网:http://www.rabbitmq.c ...

  2. 析构函数的调用------新标准c++程序设计

    示例1: #include<iostream> using namespace std; class CDemo{ public: ~CDemo(){cout<<"d ...

  3. 《Servlet和jsp学习指南》 笔记1

    chapter 1 Servlet 4个java 包: 对于每一个http请求,Servlet请求都会创建一个ServletRequest实例,并将它传给Servlet的service方法.Servl ...

  4. 洛谷P4012 深海机器人问题(费用流)

    传送门 图给的好坑……还得倒过来…… 用大佬的图做个示范 我们考虑左图吧 把每一个点向下连边,容量$1$,费用为给出的价值(表示一个机器人可以过去取得标本) 再连一条边,容量$inf$,费用$0$(表 ...

  5. Java面向对象之异常(异常处理方式)

    一.基础概念 (1)异常:Java程序在运行时期发生的不正常情况. Java就按照面向对象的思想对不正常情况进行描述和对象的封装. (2)异常问题分类: (Throwable:定义对于问题共性的功能. ...

  6. 1. C/C++项目一

    需求: 使用C语言封装string 字符串,实现字符串的增.删.改.查等API函数. 要求: 不能使用 string 库函数,所有库函数必须自己手动实现. [项目实现] myString.h 代码如下 ...

  7. ASP.NET 设计模式分为三种类型

    设计模式分为三种类型,共23类.  一.创建型模式:单例模式.抽象工厂模式.建造者模式.工厂模式.原型模式.      二.结构型模式:适配器模式.桥接模式.装饰模式.组合模式.外观模式.享元模式.代 ...

  8. 查找表 219.Contains Duplicate(2),217 Contain Duplicate, 220(3)

    思路:滑动窗口(长度为k+1)看这个窗口里的是否有两个元素的值相同.加查找表. //时间:O(n) //空间:O(k) class Solution { public: bool containsNe ...

  9. hdu 2570 贪心

    贪心的经典题型 该死的精度问题,WA了好几次,以后能用乘的绝不用除!! #include<iostream> #include<algorithm> #include<c ...

  10. [转] #!/bin/sh & #!/bin/bash区别

    [From] http://blog.51cto.com/meiling/1826201 在shell脚本的开头往往有一句话来定义使用哪种sh解释器来解释脚本.目前研发送测的shell脚本中主要有以下 ...