传送门

木材加工

题目背景

要保护环境

题目描述

木材厂有一些原木,现在想把这些木头切割成一些长度相同的小段木头(木头有可能有剩余),需要得到的小段的数目是给定的。当然,我们希望得到的小段木头越长越好,你的任务是计算能够得到的小段木头的最大长度。木头长度的单位是cm。原木的长度都是正整数,我们要求切割得到的小段木头的长度也是正整数。

例如有两根原木长度分别为11和21,要求切割成到等长的6段,很明显能切割出来的小段木头长度最长为5.

输入输出格式

输入格式

第一行是两个正整数N和K(1 ≤ N ≤ 100000,1 ≤ K ≤ 100000000),N是原木的数目,K是需要得到的小段的数目。

接下来的N行,每行有一个1到100000000之间的正整数,表示一根原木的长度。

输出格式

能够切割得到的小段的最大长度。如果连1cm长的小段都切不出来,输出"0"。

输入输出样例

输入样例 #1

3 7
232
124
456

输出样例 #1

114

分析

二分答案基础好题。

思路非常简单,二分切出的小段长度即可。

二分的左边界l显然是0,那么右边界呢?是最短的木棍吗?

我们来看这样一组数据

3 6
11
21
1

如果我们把右边界r定为最短的木棍1,显然得不到最优解。最优解根本就不会用到长度为1的木棍,所以r定这个是不行的。

我们不必拘泥于最短的木棍,因为木棍可以扔掉。所以我们可以把r大胆的定到一个位置,使得这个位置是有可能有解的,但是再+1就没解的值。

我猜你一定想到了,没错,就是把所有木棍的长度加起来/k。解最高只能是这个值了,再高就不行了,因为你没有那么多原木。

边界定了,再来看看check函数。

check函数其实也十分简单,模拟一下就行,通过截取的长度算出需要多少段,再看看切出的段数能不能到k。代码如下:

bool check(int l) {int res = 0;for (int i = 1; i <= n; ++i)res += a[i] / l;//每一根木棍可以截出多少段return res >= k;
}

到这里,我们就可以拿80分了,事实上我们还有一种情况没有判断:一根木棍都截不下来。这种情况下得到的r是0,mid就会是0,而check函数中涉及到了除以mid的操作(mid相当于函数中的l),所以你懂得。。

所以我们要来个特判,如果sum / k < 1,说明根本截不下来,这个时候直接输出0,结束程序。这样就可拿到满分啦。

代码走起。

代码

/** @Author: crab-in-the-northeast * @Date: 2020-06-16 01:01:11 * @Last Modified by: crab-in-the-northeast* @Last Modified time: 2020-06-16 01:06:58*/
#include <iostream>
#include <cstdio>const int maxn = 100005;
int n, k;
int a[maxn];bool check(int l) {int res = 0;for (int i = 1; i <= n; ++i)res += a[i] / l;return res >= k;
}int main() {std :: cin >> n >> k;int l = 0, r = 0, sum = 0;for (int i = 1; i <= n; ++i) {std :: cin >> a[i];sum += a[i];}if (sum / k < 1) {std :: cout << 0 << std :: endl;return 0;}r = sum / k;while (l <= r) {int mid = l + r >> 1;if (check(mid)) l = mid + 1;else r = mid - 1;}std :: cout << l - 1 << std :: endl;return 0;
}

评测记录

评测记录

[luogu p2440] 木材加工相关推荐

  1. 洛谷 P2440 木材加工 (二分答案)

    P2440 木材加工 题意 给定N个木头及其长度,要求把这些木头切割成M块长度相同的小段木头(木头有可能有剩余),求小段木头的最大值. 比如:有两木头长度为 11 和 21, 要求切成 6 块, 那么 ...

  2. 洛谷 P2440 木材加工(二分,含边界处理的笔记)

     题目链接: 木材加工 - 洛谷https://www.luogu.com.cn/problem/P2440 非常简单的题目,用left和right控制二分边界,ans一开始是0,每次check到符合 ...

  3. 洛谷——P2440 木材加工

    https://www.luogu.org/problem/show?pid=2440#sub 题目背景 要保护环境 题目描述 题目描述: 木材厂有一些原木,现在想把这些木头切割成一些长度相同的小段木 ...

  4. 二分答案——洛谷P2440木材加工

    题目描述 问题分析 这个题目是一类典型的二分答案问题,题目中给出我们需要将给定的长度切割成相应的K段,并且保证切割的小段的最大长度,那么我们怎么做呢,必然是在一定的区间枚举出来该切成多少才能满足切成k ...

  5. 每日一题解(第二周)

    周二 木材加工 P2440 木材加工 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 基本思路:二分查找能够符合条件的最大长度 #include<bits/stdc++.h&g ...

  6. 北理工集训 Day1—Day2 (部分算法题目)

    目录 P1678 烦恼的高考志愿 用C++进行代码实现 P2440 木材加工 用C++进行代码实现 P5705 [深基2.例7]数字反转 代码实现 P3954 [NOIP 2017 普及组] 成绩 代 ...

  7. 辛普森悖论如何影响AB测试

    Simpson's paradox occurs when we observe a certain trend in the aggregate data but not in the underl ...

  8. 二分(二分查找,二分搜索)

    二分模板 浮点数二分 double l=0,r=x; while(r-l>1e-(k+2))//保留k位小数 {double mid=(l+r)/2;if(check(mid)){l=mid;} ...

  9. 洛谷题目AC代码总结(未完成,日更题目中)

    目录 [入门1]顺序结构 [入门2]分支结构 [入门3]循环结构 [入门4]数组 [入门5]字符串 [入门6]函数与结构体 [算法1-1]模拟与高精度 [算法1-2]排序 [算法1-3]暴力枚举 [算 ...

最新文章

  1. 强强联合!Papers with Code携手arXiv,上传论文、提交代码一步到位
  2. Tableau可视化分析实战系列(三十一)-如何对超市销售数据进行可视化分析
  3. 20172311 2017-2018-2 《程序设计与数据结构》第八周学习总结
  4. VC小技巧(网上搜的)
  5. 力扣:组合总和 II DFS剪枝
  6. CSS3简介、新增选择器、属性选择器、伪元素选择器、伪元素
  7. BZOJ2081 [Poi2010]Beads
  8. office右键菜单修复_自从有了这个工具,我的Office操作已经快到慢不下来了!
  9. [ ZJOI 2006 ] Trouble
  10. Gale-Shapley算法(基于python3.6)
  11. html中表格整体居中,html中怎么把表格居中
  12. 微博十年,再次走到十字路口
  13. 使用Windows ADK 创建以U盘引导启动的Windows PE
  14. 使用微擎 微赞 微信登陆遇到redirect_uri 参数错误的设置办法
  15. alt+w热键组合无法使用
  16. 洛谷P1063 能量项链
  17. 信息化15年规划推动中国信息化步入深水区
  18. enovia PLM : add new value to SPEO
  19. 分形图java_数字的美丽——分形图形
  20. Solidity 基础(一)

热门文章

  1. SVD and LSI Tutorial 1 Understanding SVD and LSI
  2. C++面试题整理(二)
  3. php命令执行后门,php后门木马常用命令
  4. linux 修改系统时间和日期,Linux 修改系统日期和时间
  5. java.sql.SQLException: ORA-00911: 无效字符(编译器大坑)
  6. html单元格合璧,你绝对不曾见过的Excel+DOS双剑合璧操作文件夹之7大妙招
  7. git合并某个或某些提交到其他分支
  8. 上海职称不用考计算机和英语翻译,国家翻译专业资格考试将替代职称评定
  9. BI Publisher(rtf)模板开发语法大全(转)
  10. c语言程序设计植树,C语言程序设计100例之(19):欢乐的跳