제출 #65309

#제출 시각아이디문제언어결과실행 시간메모리
65309zubecRice Hub (IOI11_ricehub)C++14
100 / 100
31 ms16936 KiB

#include <bits/stdc++.h>
using namespace std;

long long a[100100], pref[100100], n, L;

bool f(int x){
    for (int i = x; i <= n; i++){
        int l = i-x+1;
        int r = i;
        int mid = (l+r)>>1;
        long long sum = (pref[r]-pref[mid])-a[mid]*1ll*(r-mid);
        sum += a[mid]*1ll*(mid-l)-(pref[mid-1]-pref[l-1]);
        if (sum <= L)
            return 1;
    }
    return 0;
}


int besthub(int n, int L, int X[], long long B){
    ::n = n;
    for (int i = 0; i < n; i++)
        a[i+1] = X[i];
    for (int i = 1; i <= n; i++){
        pref[i] = pref[i-1] + a[i];
    }
    ::L = B;
    int l = 1, r = n;
    while(l < r){
        int mid = (l+r+1)>>1;
        if (f(mid))
            l = mid; else
            r = mid-1;
    }
    return l;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...