砍伐树木

时间限制:1秒        内存限制:128M

题目描述

小华被小林叫去砍树,他需要砍倒m米长的木材。现在,小华弄到了一个奇怪的伐木机。伐木机工作过程如下:小华设置一个高度参数h(米),伐木机升起一个巨大的锯片到高度h,并锯掉所有的树比h高的部分(当然,树木不高于h米的部分保持不变)。小华就得到树木被锯下的部分。 

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

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

输入描述

第一行两个整数n和m,n表示树木的数量,m表示需要的木材总长度 

第二行n个整数,表示每棵树的高度,值均不超过10^9.保证所有木材长度之和大于m,因此必然有解

输出描述

一行一个整数,表示砍树的最高高度

输入样例

5 20
4 42 40 26 46

输出样例

36

提示

对于30%的数据:1<=n<=10,1<=m<=30 

对于70%的数据:1<=n<=10^3,1<=m<=10^4 

对于100%的数据:1<=n<=10^6,1<=m<=2*10^9

思路解析

锯子砍的高度越高,砍下的木材就越少,

所以本题考察的是二分查找的最小值最大化答案

正解代码

#include<iostream>
using namespace std;
long long n,x,a[1000005],l,r,maxx,sum,mid;
int main(){
    cin>>n>>x;
    for(int i=1;i<=n;i++){
        cin>>a[i];
        if(a[i]>maxx) maxx=a[i];//求出最大高度
    }
    l=0,r=maxx;//极限,最多和最少
    while(l<r){
        mid=(l+r+1)/2;//往高处取,题目不希望砍掉过多的树木
        sum=0;//累加砍下来的长度
        for(int i=1;i<=n;i++){
            if(a[i]>mid){
                sum+=(a[i]-mid);
            }      
        }
        if(sum<x) r=mid-1;//砍少了,锯子高度下降
        else l=mid;//砍多了,锯子高度升高
    }
    cout<<l;//输出高度
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值