news 2026/1/12 8:04:48

洛谷 P2440 木材加工 二分解法 经典二分

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
洛谷 P2440 木材加工 二分解法 经典二分

题目背景

要保护环境。

题目描述

木材厂有 n 根原木,现在想把这些木头切割成 k 段长度为 l 的小段木头(木头有可能有剩余)。

当然,我们希望得到的小段木头越长越好,请求出 l 的最大值。

木头长度的单位是 cm,原木的长度都是正整数,我们要求切割得到的小段木头的长度也是正整数。

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

输入格式

第一行是两个正整数 n,k,分别表示原木的数量,需要得到的小段的数量。

接下来 n 行,每行一个正整数 Li​,表示一根原木的长度。

输出格式

仅一行,即 l 的最大值。

如果连 1cm 长的小段都切不出来,输出0

输入输出样例

输入 #1复制

3 7 232 124 456

输出 #1复制

114

说明/提示

数据规模与约定

对于 100% 的数据,有 1≤n≤105,1≤k≤108,1≤Li​≤108(i∈[1,n])。

思路:

这是一道经典的可以用二分解决的题。我们可以考虑从1到1e8(也就是1*10^8,题目给的木头最长长度)的范围找答案,那这么大的数据很明显需要一种思路来优化一下一般的n^2的暴力查找,那么就可以想到二分,我们可以用l和r做边界,l=1,r=1e8,用 (r+l)/2=mid 做二分答案的中间值,用while(l<=r)的循环通过不断调整mid的值,用mid值作为可以切割的长度,在while循环中开个1到n的for循环,让每个完整的木头与mid整除,得到符合长度要求的木头,用cnt累加。如果cnt(当前mid值下可以切割得到满足要求的木头数或者大于,那么我们就让l=mid+1来让长度尽可能的大,反之),找到满足条件的最大切割长度 。

主播的代码:

#include <iostream> #include<queue> #include<algorithm> #include<map> #include<vector> #include<set> #include<stack> #include<string> #include<math.h> #include <iomanip> #include<unordered_map> #include <unordered_set> #include<array> #define gets(S) fgets(S,sizeof(S),stdin) #define ll long long const ll N = 1e6 + 5; const ll Max = 0x3f3f3f3f; using namespace std; ll n, m; vector<ll>saki; ll ef(ll l, ll r) { ll mid = 0, cnt = 0, ans = 0; while (l <= r) { mid = (r + l) / 2; for (int i = 1; i <= n; i++) { cnt += saki[i] / mid; } if (cnt < m) { r = mid - 1; } else { l = mid + 1; } cnt = 0; } return r; } int main() { cin >> n >> m; saki.resize(n + 1); for (int i = 1; i <= n; i++) { cin >> saki[i]; } ll l = 1, r = 1e8; cout << ef(l, r) << endl; return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/9 14:40:46

OpenAI 的反击!GPT-5.2 强行拉开代差,Gemini 3 和 Claude 4 还有机会吗?

2025 年 12 月&#xff0c;全球 AI 领域爆发了一场足以载入史册的“圣诞闪击战”。 当谷歌的Gemini 3凭借其深度多模态能力刚刚在创意界站稳脚跟&#xff0c;Anthropic 的 Claude 4 靠着“软工程最强”的口碑收割开发者时&#xff0c;OpenAI 突然抛出了王牌——GPT-5.2。这不仅…

作者头像 李华
网站建设 2026/1/3 19:38:06

零售打工人加薪难?靠这张证,我在激烈竞争里站稳了脚跟

在零售商贸行业摸爬滚打三年&#xff0c;我深刻体会到“内卷”二字的重量。货架补货、客户接待、业绩冲刺&#xff0c;每天重复的工作占据了大部分时间&#xff0c;可薪资条上的数字却始终原地踏步。看着身边同事为了一个晋升名额争得头破血流&#xff0c;新人带着新鲜技能不断…

作者头像 李华
网站建设 2026/1/6 16:08:42

从离线语音到多模态智能体四博智联 AI 硬件整体解决方案全景解析

下面是一篇完整、可直接对外发布的推广文章&#xff0c;我已经严格基于你提供的《四博智联 AI 开发宝典》内容进行整理与升华&#xff0c;把零散的技术说明统一成一条清晰的 「四博智联 AI 方案全景路线」&#xff0c;适合用于&#xff1a;官网 / 公众号招商 / 客户方案介绍AI …

作者头像 李华
网站建设 2026/1/5 3:59:31

性能压测工具:wrk

一般我们压测的时候&#xff0c;需要了解衡量系统性能的一些参数指标&#xff0c;比如。 1、性能指标简介 1.1 延迟 简单易懂。green:一般指响应时间 95线&#xff1a;P95。平均100%的请求中95%已经响应的时间 99线&#xff1a;P99。平均100%的请求中99%已经响应的时间 平…

作者头像 李华