http://www.lydsy.com/JudgeOnline/problem.php?id=1082 (题目链接)

题意

  给出m块木柴,以及n块木板,要求将m块木柴做木板,要求将木柴切割成与木板一样的长度,问最多可以做成几块木板。

Solution

  今日考题。乍一看,好像可以二分,然而并不会check,于是码了个贪心,10分mdzz。。

  正解:二分+搜索。

  每次二分答案mid后,对每块木板进行搜索,枚举用那根木柴去进行切割。没想到剪枝这么强大,这都可以搜过去。。

  剪枝1:一开始将不符合条件的某些木柴与木板去掉。

  剪枝2:有些木柴经过切割后已经比最短的木板更短,将剩下的长度加到一个变量Waste中,判断是否  Waste + mid块木板总长度>木柴总长度。

  剪枝3:若某块木板在之前已经搜索过了,直接从当时被切割的木柴处进行搜索。

代码

  1. // bzoj1082
  2. #include<algorithm>
  3. #include<iostream>
  4. #include<cstdlib>
  5. #include<cstring>
  6. #include<cstdio>
  7. #include<cmath>
  8. #include<queue>
  9. #define LL long long
  10. #define inf 2147483640
  11. #define MOD 1000000009
  12. #define Pi acos(-1.0)
  13. #define free(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout);
  14. using namespace std;
  15.  
  16. const int maxn=10010;
  17. int a[maxn],b[maxn],S,sum[maxn],bl[maxn];
  18. int n,m,flag,mid;
  19.  
  20. void dfs(int x,int p,int w) {
  21. if (x==0) {flag=1;return;}
  22. while (p<=n && a[p]<b[1]) {w+=a[p];p++;}
  23. if (w+sum[mid]>S || flag || p>n) return;
  24. int t=p;
  25. if (b[x]==b[x+1] && x!=mid) t=bl[x+1];
  26. for (int i=t;i<=n;i++) if (a[i]>=b[x]) {
  27. bl[x]=i;
  28. a[i]-=b[x];dfs(x-1,p,w);
  29. a[i]+=b[x];
  30. if (flag) return;
  31. }
  32. }
  33. int main() {
  34. scanf("%d",&n);
  35. for (int i=1;i<=n;i++) scanf("%d",&a[i]);
  36. scanf("%d",&m);
  37. for (int i=1;i<=m;i++) scanf("%d",&b[i]);
  38. sort(a+1,a+1+n);
  39. sort(b+1,b+1+m);
  40. while (b[m]>a[n]) m--;
  41. int tot=0;
  42. for (int i=1;i<=n;i++) if (a[i]>b[1]) a[++tot]=a[i];
  43. n=tot;S=0;sum[0]=0;
  44. for (int i=1;i<=n;i++) S+=a[i];
  45. for (int i=1;i<=m;i++) sum[i]=sum[i-1]+b[i];
  46. int L=1,R=m,ans=0;
  47. while (L<=R) {
  48. mid=(L+R)>>1;
  49. flag=0;dfs(mid,1,0);
  50. if (flag) ans=mid,L=mid+1;
  51. else R=mid-1;
  52. }
  53. printf("%d\n",ans);
  54. return 0;
  55. }

  

【bzoj1082】 SCOI2005—栅栏的更多相关文章

  1. [BZOJ1082][SCOI2005]栅栏 二分+搜索减枝

    1082: [SCOI2005]栅栏 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2430  Solved: 1034[Submit][Status ...

  2. bzoj1082: [SCOI2005]栅栏(二分答案搜索判断)

    1082: [SCOI2005]栅栏 题目:传送门 题解: 是不是一开始在想DP?本蒟蒻也是qwq,结果很nice的错了ORZ 正解:二分+搜索 我们可以先把两种木材都进行排序,那么如果需要的最大木材 ...

  3. bzoj1082[SCOI2005]栅栏

    Description 农夫约翰打算建立一个栅栏将他的牧场给围起来,因此他需要一些特定规格的木材.于是农夫约翰到木材店购 买木材.可是木材店老板说他这里只剩下少部分大规格的木板了.不过约翰可以购买这些 ...

  4. BZOJ1082: [SCOI2005]栅栏 题解

    题目大意: 有一些木材,可以没有浪费地将一根木材分成几块木板(比如长度为10的木板可以切成长度为8和2的两块木板).现在你希望得到一些长度的木板,问通过分割木材最多能得到几块想要的木板. 思路: 首先 ...

  5. 【BZOJ1082】[SCOI2005]栅栏(搜索)

    [BZOJ1082][SCOI2005]栅栏(搜索) 题面 BZOJ 洛谷 题解 随便写个爆搜,洛谷上就\(80\)分了.先放爆搜代码: #include<iostream> #inclu ...

  6. 洛谷 P2329 [SCOI2005]栅栏 解题报告

    P2329 [SCOI2005]栅栏 题目描述 农夫约翰打算建立一个栅栏将他的牧场给围起来,因此他需要一些特定规格的木材.于是农夫约翰到木材店购买木材.可是木材店老板说他这里只剩下少部分大规格的木板了 ...

  7. bzoj 1082: [SCOI2005]栅栏 题解

    1082: [SCOI2005]栅栏 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2340  Solved: 991[Submit][Status] ...

  8. 【bzoj1082】栅栏[SCOI2005]

    显然我们取的肯定是前ans块木板.然后砍的木材也应该是从小到大砍(如果小的木材可以满足条件,就一定不会去动大的木材) 所以两遍排序. 二分答案. 然后对于要取的每块木板,我们搜索它是在第x块木板上砍下 ...

  9. SCOI2005栅栏

    Description 农夫约翰打算建立一个栅栏将他的牧场给围起来,因此他需要一些特定规格的木材.于是农夫约翰到木材店购买木材.可是木材店老板说他这里只剩下少部分大规格的木板了.不过约翰可以购买这些木 ...

随机推荐

  1. Notes: Principles of fMRI 1 (Coursera)

    course link: https://class.coursera.org/fmri1-001 Part 1  ❤ Three fundmental goals in fMRI: localiza ...

  2. C# 发送邮件,QQ企业邮箱测试成功

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.N ...

  3. maven buid 导出项目依赖的jar包问题

    [ERROR] Failed to execute goal org.apache.maven.plugins:maven-dependency-plugin:2.8:copy-dependencie ...

  4. 批量修改string中的字符

    #1,修改"/"为"\\",多用于在txt读取内容后进行修改 size_t pos0 = mkfolder.find("/");//首次查找 ...

  5. java并发:同步容器&并发容器

    第一节 同步容器.并发容器 1.简述同步容器与并发容器 在Java并发编程中,经常听到同步容器.并发容器之说,那什么是同步容器与并发容器呢?同步容器可以简单地理解为通过synchronized来实现同 ...

  6. [已开源/文章教程]独立开发 一个社交 APP 的源码/架构分享 (已上架)

    0x00 背景 真不是和被推荐了2天的博客园一位大神较真,从他那篇文章的索引式文章内容也学习到了很多东西,看评论区那么多对社交APP源码有兴趣的,正巧我上周把我的一个社交APP开源了,包括androi ...

  7. 基于PHP的AJAX学习笔记(教程)

    本文转载自:http://www.softeng.cn/?p=107 这是本人在学习ajax过程所做的笔记,通过本笔记的学习,可以完成ajax的快速入门.本笔记前端分别使用原生态的javascript ...

  8. javascript 中加’var‘和不加'var'的区别,你真的懂吗?

    没看之前千万别说我是标题党,这个问题真的有好多淫都不懂!!! 大家都看了很多文章,都说避免隐式声明全局变量,就是说声明变量前必须加'var',那加了'var'和不加'var'到底有啥区别呢? 先来看一 ...

  9. ASP.NET 系列:单元测试之StructureMap

    ASP.NET使用StructureMap等依赖注入组件时最重要就是EntityFramework的DbContext对象要保证在每次HttpRequest只有一个DbContext实例,这里将使用第 ...

  10. ASP.NET Web API(三):安全验证之使用摘要认证(digest authentication)

    在前一篇文章中,主要讨论了使用HTTP基本认证的方法,因为HTTP基本认证的方式决定了它在安全性方面存在很大的问题,所以接下来看看另一种验证的方式:digest authentication,即摘要认 ...