news 2026/4/16 18:03:00

洛谷 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/4/16 12:44:02

GMSSL:国密算法SM2、SM3、SM4的高效实现

GMSSL是一个支持国家密码算法&#xff08;国密算法&#xff09;的开源密码工具库。GMSSL提供了与OpenSSL类似的功能&#xff0c;主要包括&#xff1a;国密算法实现&#xff08;SM2/SM3/SM4等&#xff09;&#xff1b;证书管理&#xff08;支持国密标准证书格式&#xff09;&…

作者头像 李华
网站建设 2026/4/16 11:11:41

08_软考_法律法规与标准化

知识产权基础知识 保护期限知识产权人的确定侵权判定其他法律细则标准化基础知识 标准的分类标准的编号

作者头像 李华
网站建设 2026/4/16 0:28:26

AI原生应用:开启视频生成新时代

AI原生应用:开启视频生成新时代 关键词:AI原生应用、视频生成、人工智能、深度学习、生成模型、应用场景、未来趋势 摘要:本文深入探讨AI原生应用如何开启视频生成的新时代。通过介绍相关核心概念,阐述核心算法原理及操作步骤,展示项目实战案例,分析实际应用场景,推荐工…

作者头像 李华
网站建设 2026/4/16 0:32:17

9 个高效降AI率工具,继续教育学生必备!

9 个高效降AI率工具&#xff0c;继续教育学生必备&#xff01; AI降重工具&#xff1a;高效降低AIGC率&#xff0c;让论文更自然 在当前学术写作中&#xff0c;随着AI技术的广泛应用&#xff0c;越来越多的学生和研究人员发现&#xff0c;使用AI生成的内容容易被查重系统识别为…

作者头像 李华
网站建设 2026/4/16 13:37:12

克隆大型仓库卡住(7%每次就卡住了)

克隆到7%就卡住&#xff0c;核心是大文件传输时网络链路不稳定&#xff08;SSH 连接因长时间低速率传输被远端/防火墙掐断&#xff09;&#xff0c;且单纯增大缓冲区效果有限&#xff0c;需要针对性优化「传输策略」和「连接保活」&#xff0c;以下是按优先级排序的解决方法&am…

作者头像 李华