hiho week 69 register

Ended

Participants:406

Verdict:Accepted
Score:100 / 100
Submitted:2015-10-30 16:14:37

Lang:G++

Edit
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <stdio.h>
#define MAXN 100000
int getScore(int *arr, int n, int t) {
    int last = 0, cur = 0;
    int score = 0;
    for (int i = 0; i < n; i++) {
        if (t + last > arr[i]) {
            score++;
            last = t + last - arr[i];
        } else {
            last = 0;
        }
    }
    return score;
}
int main() {
    int n, k;
    int arr[MAXN];
    scanf("%d%d", &n, &k);
    for (int i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
    }
    int left = 0, right = k + 1, mid;
    int hold = n / 2 + 1;
    int score;
    while (left + 1 < right) {
        mid = (left + right) / 2;
        score = getScore(arr, n, mid);
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX