乔斯编程——伐木工

乔斯编程——伐木工二分答案模板题 枚举的优化 伐木工人米尔科需要砍倒 m 米长的木材

大家好,欢迎来到IT知识分享网。

题目描述

伐木工人米尔科需要砍倒M米长的木材。这是一个对米尔科来说很容易的工作,因为他有一个漂亮的新伐木机,可以像野火一样砍倒森林。不过,米尔科只被允许砍倒单行树木。

米尔科的伐木机工作过程如下:米尔科设置一个高度参数H(米),伐木机升起一个巨大的锯片到高度H,并锯掉所有的树比H高的部分(当然,树木不高于H米的部分保持不变)。米尔科就行到树木被锯下的部分。

例如,如果一行树的高度分别为20,15,10和17,米尔科把锯片升到15米的高度,切割后树木剩下的高度将是15,15,10和15,而米尔科将从第1棵树得到5米,从第4棵树得到2米,共得到7米木材。

米尔科非常关注生态保护,所以他不会砍掉过多的木材。这正是他为什么尽可能高地设定伐木机锯片的原因。帮助米尔科找到伐木机锯片的最大的整数高度H,使得他能得到木材至少为M米。换句话说,如果再升高1米,则他将得不到M米木材。

输入格式

第1行:2个整数 NN 和 MM,NN 表示树木的数量 (1<=N<=1061<=N<=106),M表示需要的木材总长度(1<=M<=2∗1091<=M<=2∗109)

第2行:N个整数表示每棵树的高度,值均不超过。所有木材长度之和大于M,因此必有解。

输出格式

1个整数,表示砍树的最高高度。

输入数据 1

5 20 4 42 40 26 46 

输出数据 1

36

代码 

#include<bits/stdc++.h> using namespace std; long long n, m, a[int(1e6 + 5)]; bool check(long long h) { long long sum = 0; for (int i = 1; i <= n; i++) { if (a[i] > h) { sum += a[i] - h; } } return sum >= m; } int main() { ios::sync_with_stdio(false); cin.tie(0); cout.tie(0); cin >> n >> m; for (int i = 1; i <= n; i++) cin >> a[i]; long long l = 0, r = 1e10, ans = -1; while (l <= r) { long long mid = (l + r) / 2; if (check(mid)) { ans = mid; l = mid + 1; } else { r = mid - 1; } } cout << ans; return 0; }

AC合格证

乔斯编程——伐木工

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/141322.html

(0)
上一篇 2025-05-17 22:26
下一篇 2025-05-17 22:33

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信