32| 伐木

代码实现

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

#define int long long
const int N = 1e6 + 10;
int n, m,z;
int a[N];

int check(int mid)
{
	int cnt = 0;
	for (int i = 1; i <= n; i++) 
	{
		int x = a[i] - mid;
		if (x > 0) cnt += x;
	}
	return cnt;
}
signed main()
{
	cin >> n >> m;
	for (int i = 1; i <= n; i++) 
	{
		int x; cin >> x;
		a[i] = x;
		z = max(z, x);
	}
	int l = 1, r = z, mid;
	while(l < r)
	{
		mid = (l + r + 1) >> 1;
		if(check(mid) >= m) l = mid;
		else r = mid - 1;
	}
	cout << l << endl;
	return 0;
 } 
相关推荐
2401_892070984 分钟前
算法与数据结构精讲:最大子段和(暴力 / 优化 / 分治)+ 线段树从入门到实战
c++·算法·线段树·最大子段和
memcpy06 分钟前
LeetCode 904. 水果成篮【不定长滑窗+哈希表】1516
算法·leetcode·散列表
老四啊laosi16 分钟前
[双指针] 8. 四数之和
算法·leetcode·四数之和
汀、人工智能17 分钟前
[特殊字符] 第24课:反转链表
数据结构·算法·链表·数据库架构··反转链表
田梓燊22 分钟前
leetcode 41
数据结构·算法·leetcode
正经教主31 分钟前
【docker基础】0、系统学习docker之总计划
学习·docker·容器
_深海凉_32 分钟前
LeetCode热题100-三数之和
算法·leetcode·职场和发展
y = xⁿ1 小时前
【LeetCode】双指针合集
算法·leetcode
2601_949539451 小时前
家用新能源 SUV 核心技术科普:后排娱乐、空间工程与混动可靠性解析
大数据·网络·人工智能·算法·机器学习
凌波粒1 小时前
LeetCode--18.四数之和(双指针法)
数据结构·算法·leetcode