美文网首页
2020-09-17 砍树

2020-09-17 砍树

作者: JalorOo | 来源:发表于2020-09-17 21:09 被阅读0次

https://www.luogu.com.cn/problem/P1873

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <sstream>
#include <algorithm>
#include <cstring>
#include <vector>
#include <queue>
using namespace std;

//template<typename DataType>
//DataType qmi(DataType m, int k)
//{
//    DataType res = 1, t = m;
//    while (k)
//    {
//        if (k&1) res = res * t;
//        t = t * t;
//        k >>= 1;
//    }
//    return res;
//}


int qmi(int m, int k)
{
    int res = 1, t = m;
    while (k)
    {
        if (k&1) res = res * t;
        t = t * t;
        k >>= 1;
    }
    return res;
}

int read(){
    int x = 0,f = 1;
    char c = getchar();
    while (c<'0'||c>'9') {
        if (c=='-') {
            f = -1;
        }
        c = getchar();
    }
    while (c>='0'&&c<='9') {
        x = x*10+c-'0';
        c = getchar();
    }
    return x*f;
}

#define fi(a,b) for(int i = a; i < b; i++)
#define fie(a,b) for(int i = a; i <= b; i++)
#define fj(a,b) for(int j = a; j >= b; j--)

struct priceAndCnt{
    int price,cnt;
};

void quickSort(priceAndCnt *a,int left,int right){
    int i,j;
    
    priceAndCnt temp,t;
    
    temp = a[(left+right)/2];//基准值
    
    i = left;
    j = right;
    
    while(i<=j){
        while (a[j].price > temp.price) {
            j--;
        }
        
        while (a[i].price < temp.price) {
            i++;
        }
        
        if (i<=j) {
            t = a[i];
            a[i] = a[j];
            a[j] = t;
            //继续下一步
            i++;
            j--;
        }
    }
    
    if(left<j)quickSort(a,left, j);//继续分治
    if(i<right)quickSort(a,i, right);//继续分治
}


int n;
long long m;
long long lef,rig = 0;
long long mid;//看上面的解释啊
int total,tim;//这个不用管,后面会提到的

bool Judge(long long x,long long * a)
{
    long long ans = 0;
    fie(1,n){//这里大家应该看得出,是在用贪心来看一看这个最大值是否能为x
        long long t = a[i] - x;
        if (t > 0) {
            ans += t;
        }
    }
    
    return ans < m;//返回结果}
}

int main()
{
    cin>>n>>m;
    
    long long a[n];
    
    fie(1, n){
        cin>>a[i];
        rig=max(rig,a[i]);//找到最长木材
    }
    
    lef = 0;
    while (lef <= rig){//非递归式二分正常向写法,可理解为一般框架
        mid = (lef + rig) / 2;//这再看不出是啥意思可以退群了
        if ( Judge(mid,a) ){//是否小了
            rig = mid - 1;
        } else {
            lef = mid + 1;
        }
    }
    cout<<lef - 1<<endl;
    return 0;
}
/*
5 20
4 42 40 26 46
============
36
*/

相关文章

  • 2020-09-17 砍树

    https://www.luogu.com.cn/problem/P1873

  • 砍树

    今夜加班给客户栽树,因为在写字楼砍树。白天容易影响行人,所以改在晚上工作。记得三年前也因为一个单子加班到凌晨。三年...

  • 砍树

    上次说接着砍树的事,也就是跟一老太太交锋,自己是占理的一方,却被老太太完败的事儿。 发现跟老太太讲理讲不通,因为她...

  • 砍树

    天边的火烧云,燃烧得很艳丽;酷热已经消去,温柔的晚风,轻轻地吹着。冬冬站在楼顶朝村口望着,时不时的数着电线杆上的麻...

  • 砍树

    今天和我爸去林子里锯两棵树: 一个是白杨,另一个也是白杨。 我爸说一人扛一棵回来! 用手比划一下就做梯子的树不粗。...

  • 砍树

    一位学生觉得自己总是苦学无果,跑去请教他的教授。教授笑着问他:“如果你去山上砍树,看到两棵树,一棵粗,一棵细,你会...

  • 砍树

    (阿呆系列第23首) 树那么美。就让它长在山上 为什么要砍树? 真是个书呆子 树在山上 长的再好跟你无关 砍回家来...

  • 砍树

    他是读过几年书。 但是毕业出来找不到什么工作。他回到家,告诉祖母自己找不到工作。祖母没有骂他,只对他说:“后山上有...

  • 砍树

    午后三点,窗外烈阳高照,阳光在高大的树影之间挥毫泼墨。 午睡起来准备烧水品茗,忽然从外面传来很响的...

  • 砍树

    夏日正盛,雨水充足,一切都在热闹的生长着。 电锯刷刷作响,几个人拉着一端绑在树上的绳子,那边在搬木头的两个人刚刚停...

网友评论

      本文标题:2020-09-17 砍树

      本文链接:https://www.haomeiwen.com/subject/uepryktx.html