传送门

2456 栅栏

2006年省队选拔赛四川

 时间限制: 1 s
 空间限制: 128000 KB
 题目等级 : 大师 Maste
 
题目描述 Description

农夫约翰打算建立一个栅栏将他的牧场给围起来,因此他需要一些特定规格的木材。于是农夫约翰到木材店购买木材。可是木材店老板说他这里只剩下少部分大规格的木板了。不过约翰可以购买这些木板,然后切割成他所需要的规格。而且约翰有一把神奇的锯子,用它来锯木板,不会产生任何损失,也就是说长度为10的木板可以切成长度为8和2的两个木板。

你的任务:给你约翰所需要的木板的规格,还有木材店老板能够给出的木材的规格,求约翰最多能够得到多少他所需要的木板。

输入描述 Input Description

第一行为整数m(m<= 50)表示木材店老板可以提供多少块木材给约翰。紧跟着m行为老板提供的每一块木板的长度。接下来一行(即第m+2行)为整数n(n <= 1000),表示约翰需要多少木材。接下来n行表示他所需要的每一块木板的长度。木材的规格小于32767。(对于店老板提供的和约翰需要的每块木板,你只能使用一次)。

输出描述 Output Description

只有一行,为约翰最多能够得到的符合条件的木板的个数。

样例输入 Sample Input
4
30
40
50
25
10
15

16

17
18
19
20
21
25
24

30

样例输出 Sample Output

7

数据范围及提示 Data Size & Hint

见题面

【题目大意】

给你几块一定长度而木材,问最多能切多少块需要长度的木块。

【思路1】

哈哈哈30分暴力 好高兴哦\\QWq//

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int m,n,l[],ned[],vis[],ans,res=-0x7ffff;
void dfs(int x) {
if(x==n+) {
res=max(res,ans);
return ;
}
for(int i=; i<=m; i++) {
if(l[i]>ned[x]) {
l[i]-=ned[x];
ans++;
dfs(x+);
l[i]+=ned[x];
ans--;
}
}
dfs(x+);
}
int main() {
scanf("%d",&m);
for(int i=; i<=m; i++)
scanf("%d",&l[i]);
scanf("%d",&n);
for(int i=; i<=n; i++)
scanf("%d",&ned[i]);
sort(l+,l+m+);
sort(ned+,ned+n+);
dfs();
printf("%d\n",res);
return ;
}

【思路2--正解】

二分搜索+剪枝

我真没看出来这个题是二分......

二分剪mid块。剪最小的mid块....

说一下剪枝

(1) 如果浪费的木材+我们二分需要的木材大于商店给出的木材和false。

(2)如果需要的木材有两块相同的话,再dfs时不需要从1开始找切哪块木材,从上一次for循环开始搜。

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int n,m,ned[],nes[],l[];
int sum,ans,was;
inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
bool dfs(int get,int from) {
if(!get)return true;
if(was+nes[get]>sum)return false;
bool can=;
for(int i=from; i<=m; i++) {
if(l[i]>=ned[get]) {
l[i]-=ned[get];
if(l[i]<ned[])was+=l[i];
if(ned[get]==ned[get-])
can=dfs(get-,i);
else
can=dfs(get-,);
if(l[i]<ned[])
was-=l[i];
l[i]+=ned[get];
if(can)return true;
}
}
return false;
}
int main() {
m=read();
for(int i=; i<=m; i++) {
l[i]=read();
sum+=l[i];
}
n=read();
for(int i=; i<=n; i++)
ned[i]=read();
sort(l+,l+m+);
sort(ned+,ned+n+);
for(int i=; i<=n; i++)
nes[i]=nes[i-]+ned[i];
for(; nes[n]>sum;)n--;
int lt=,rt=n;
while(lt<=rt) {
// was=0;
int mid=lt+(rt-lt)/;
if(dfs(mid,))ans=mid,lt=mid+;
else
rt=mid-;
}
printf("%d\n",ans);
return ;
}

codevs 2456栅栏的更多相关文章

  1. codevs 水过 骑马修栅栏

    [问题描述] 农民John每年有很多栅栏要修理.他总是骑着马穿过每一个栅栏并修复它破损的地方. John是一个与其他农民一样懒的人.他讨厌骑马,因此从来不两次经过一个一个栅栏.你必须编一个程序,读入栅 ...

  2. codevs 2039 骑马修栅栏 USACO x

    题目描述 Description Farmer John每年有很多栅栏要修理.他总是骑着马穿过每一个栅栏并修复它破损的地方. John是一个与其他农民一样懒的人.他讨厌骑马,因此从来不两次经过一个栅栏 ...

  3. [ CodeVS冲杯之路 ] P2456

    不充钱,你怎么AC? 题目:http://codevs.cn/problem/2456/ 用贪心的思想,木材当然要尽量分成多的木板,而大的木材能够分成大木板,但是小的木材不一定能够分成大的木板,所以木 ...

  4. codevs 3289 花匠

    题目:codevs 3289 花匠 链接:http://codevs.cn/problem/3289/ 这道题有点像最长上升序列,但这里不是上升,是最长"波浪"子序列.用动态规划可 ...

  5. codevs 1082 线段树练习 3(区间维护)

    codevs 1082 线段树练习 3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...

  6. codevs 1285 二叉查找树STL基本用法

    C++STL库的set就是一个二叉查找树,并且支持结构体. 在写结构体式的二叉查找树时,需要在结构体里面定义操作符 < ,因为需要比较. set经常会用到迭代器,这里说明一下迭代器:可以类似的把 ...

  7. codevs 1576 最长上升子序列的线段树优化

    题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...

  8. codevs 1080 线段树点修改

    先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...

  9. codevs 1228 苹果树 树链剖分讲解

    题目:codevs 1228 苹果树 链接:http://codevs.cn/problem/1228/ 看了这么多树链剖分的解释,几个小时后总算把树链剖分弄懂了. 树链剖分的功能:快速修改,查询树上 ...

随机推荐

  1. 转:Android IOS WebRTC 音视频开发总结 (系列文章集合)

    随笔分类 - webrtc   Android IOS WebRTC 音视频开发总结(七八)-- 为什么WebRTC端到端监控很关键? 摘要: 本文主要介绍WebRTC端到端监控(我们翻译和整理的,译 ...

  2. Redis简单介绍以及数据类型存储

    因为我们在大型互联网项目其中.用户訪问量比較大,比較多.会产生并发问题,对于此.我们该怎样解决呢.Redis横空出世,首先,我们来简单的认识一下Redis.具体介绍例如以下所看到的: Redis是一个 ...

  3. 使用fuser命令kill一个终端(特殊文件)的方法

    /*********************************************************************  * Author  : Samson  * Date   ...

  4. Linux虚拟服务器--LVS

    LVS 百科名片 LVS是一个开源的软件,由毕业于国防科技大学的章文嵩博士于1998年5月创立,可以实现LINUX平台下的简单负载均衡.LVS是Linux Virtual Server的缩写,意思是L ...

  5. Codeforces Round #267 (Div. 2) B. Fedor and New Game

    After you had helped George and Alex to move in the dorm, they went to help their friend Fedor play ...

  6. 流迭代器 + 算法灵活控制IO流

    前言 标准算法配合迭代器使用太美妙了,使我们对容器(数据)的处理更加得心应手.那么,能不能对IO流也使用标准算法呢?有人认为不能,他们说因为IO流不是容器,没有迭代器,故无法使用标准算法.他们错了,错 ...

  7. hbase shell删除没实用

    用Xshell登陆linux主机后,在hbase shell下不能使用backspace和delete删除误输的指令,这是Xshell的配置问题: 在File->Properties->T ...

  8. MVC入门——列表页

    创建控制器UserInfoController using System; using System.Collections.Generic; using System.Linq; using Sys ...

  9. checkAll全选的一个小例子

    function checkAll(tag,flag) { //得到所有check var checkboxs = $(tag).closest("table").find(&qu ...

  10. c# vs2010 连接access数据库

    第一次在博客园写博文,由于文采不怎么好,即使是自己很熟悉的东西,写起来也会感觉到不知从何讲起,我想写的多了就好了. 这篇文章主要是介绍怎么用c# 语言 vs2010连接access数据库的,连接字符串 ...