• Coffee and Coursework (Hard Version)


    Coffee and Coursework (Hard Version)
    time limit per test
    2.5 seconds
    memory limit per test
    256 megabytes
    input
    standard input
    output
    standard output

    The only difference between easy and hard versions is the constraints.

    Polycarp has to write a coursework. The coursework consists of mm pages.

    Polycarp also has nn cups of coffee. The coffee in the ii -th cup Polycarp has aiai caffeine in it. Polycarp can drink some cups of coffee (each one no more than once). He can drink cups in any order. Polycarp drinks each cup instantly and completely (i.e. he cannot split any cup into several days).

    Surely, courseworks are not being written in a single day (in a perfect world of Berland, at least).

    Let's consider some day of Polycarp's work. Consider Polycarp drinks kk cups of coffee during this day and caffeine dosages of cups Polycarp drink during this day are ai1,ai2,,aikai1,ai2,…,aik . Then the first cup he drinks gives him energy to write ai1ai1 pages of coursework, the second cup gives him energy to write max(0,ai21)max(0,ai2−1) pages, the third cup gives him energy to write max(0,ai32)max(0,ai3−2) pages, ..., the kk -th cup gives him energy to write max(0,aikk+1)max(0,aik−k+1) pages.

    If Polycarp doesn't drink coffee during some day, he cannot write coursework at all that day.

    Polycarp has to finish his coursework as soon as possible (spend the minimum number of days to do it). Your task is to find out this number of days or say that it is impossible.

    Input

    The first line of the input contains two integers nn and mm (1n21051≤n≤2⋅105 , 1m1091≤m≤109 ) — the number of cups of coffee and the number of pages in the coursework.

    The second line of the input contains nn integers a1,a2,,ana1,a2,…,an (1ai1091≤ai≤109 ), where aiai is the caffeine dosage of coffee in the ii -th cup.

    Output

    If it is impossible to write the coursework, print -1. Otherwise print the minimum number of days Polycarp needs to do it.

    Examples
    Input
    Copy
    5 8
    2 3 1 1 2
    
    Output
    Copy
    4
    
    Input
    Copy
    7 10
    1 3 4 2 1 4 2
    
    Output
    Copy
    2
    
    Input
    Copy
    5 15
    5 5 5 5 5
    
    Output
    Copy
    1
    
    Input
    Copy
    5 16
    5 5 5 5 5
    
    Output
    Copy
    2
    
    Input
    Copy
    5 26
    5 5 5 5 5
    
    Output
    Copy
    -1
    
    Note

    In the first example Polycarp can drink fourth cup during first day (and write 11 page), first and second cups during second day (and write 2+(31)=42+(3−1)=4 pages), fifth cup during the third day (and write 22 pages) and third cup during the fourth day (and write 11 page) so the answer is 44 . It is obvious that there is no way to write the coursework in three or less days.

    In the second example Polycarp can drink third, fourth and second cups during first day (and write 4+(21)+(32)=64+(2−1)+(3−2)=6 pages) and sixth cup during second day (and write 44 pages) so the answer is 22 . It is obvious that Polycarp cannot write the whole coursework in one day in this test.

    In the third example Polycarp can drink all cups of coffee during first day and write 5+(51)+(52)+(53)+(54)=155+(5−1)+(5−2)+(5−3)+(5−4)=15 pages of coursework.

    In the fourth example Polycarp cannot drink all cups during first day and should drink one of them during the second day. So during first day he will write 5+(51)+(52)+(53)=145+(5−1)+(5−2)+(5−3)=14 pages of coursework and during second day he will write 55 pages of coursework. This is enough to complete it.

    In the fifth example Polycarp cannot write the whole coursework at all, even if he will drink one cup of coffee during each day, so the answer is -1.

    分析:大数据,既然已经使用sort排序了,直接二分就可以了鸭

     1 #include<iostream>
     2 #include<cstdio>
     3 #include<algorithm>
     4 using namespace std;
     5 #define ll long long
     6 int n,m;
     7 vector<int> a;
     8 
     9 bool can(int i){
    10     ll sum=0;
    11     for( int j=0; j<n; j++ ){
    12         sum+=max(a[j]-j/i,0);
    13     }
    14     if(sum>=m)return true;
    15     else return false;
    16 }
    17 
    18 int main(int argc, char const *argv[])
    19 {
    20     cin>>n>>m;
    21     a=vector<int>(n);
    22 
    23     for( int i=0; i<n; i++ ){
    24         cin>>a[i];
    25     }
    26 
    27     sort(a.rbegin(),a.rend());
    28 
    29     int l=1,r=n;
    30     while(l<=r){
    31         ll mid=(l+r) >> 1;
    32         if(can(mid)) r=mid-1;
    33         else l=mid+1;
    34     }
    35 
    36     if(can(l)) cout<<l<<endl;
    37     // else if(can(r)) cout<<r<<endl;
    38     else{
    39         cout<<-1<<endl;
    40     }
    41 
    42     return 0;
    43 }
    有些目标看似很遥远,但只要付出足够多的努力,这一切总有可能实现!
  • 相关阅读:
    MVC简介
    Scrapy中的item是什么
    Git删除文件操作
    vi编辑文件出现Can't open file for writing错误
    CentOs安装Scrapy出现error: Setup script exited with error: command ‘gcc’ failed with exit status 1错误解决方案
    Python脚本运行出现语法错误:IndentationError: unindent does not match any outer indentation level
    激活MyEclipse 6.5方法-通过一段Java程序生成激活码
    oninput,onpropertychange,onchange的用法和区别【转载】
    Myeclipse6.5项目启动时由于数据库连接失败的错误日志
    IE和Firefox的Javascript兼容性总结
  • 原文地址:https://www.cnblogs.com/Bravewtz/p/10465896.html
Copyright © 2020-2023  润新知