#include <iostream>
#include <cstdio>
#include <algorithm>
typedef long long LL;
using namespace std;
const int MAX = 500000;
int n;
int m;
int a[MAX];
LL high[MAX];
LL prevD[MAX];
int compare (const void * a, const void * b)
{
return ( *(int*)b - *(int*)a );
}
int main() {
LL d = 0, b = 0;
LL sum, currentCut;
int tmp, i, j;
scanf("%d %d", &n, &m);
for(int i=0; i<n; i++) {
scanf("%d", &tmp);
a[i] = tmp;
}
qsort(a, n, sizeof(int), compare);
for(i=0; i<m; i++) {
scanf("%lld %lld", &d, &b);
sum = 0;
j = 0;
while(j < n) {
currentCut = high[j] + LL(a[j]) * (d - prevD[j]) - b;
if(currentCut <= 0) {
// if b is higher than the current grass - grasses are from highest to lowest
// then sum remains
break;
}
high[j] = b;
prevD[j] = d;
sum += currentCut;
j++;
};
// otherwise: if b is higher than the higher grass
// then sum remains 0
printf("%lld\n", sum);
}
return 0;
}
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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | #include <iostream> #include <cstdio> #include <algorithm> typedef long long LL; using namespace std; const int MAX = 500000; int n; int m; int a[MAX]; LL high[MAX]; LL prevD[MAX]; int compare (const void * a, const void * b) { return ( *(int*)b - *(int*)a ); } int main() { LL d = 0, b = 0; LL sum, currentCut; int tmp, i, j; scanf("%d %d", &n, &m); for(int i=0; i<n; i++) { scanf("%d", &tmp); a[i] = tmp; } qsort(a, n, sizeof(int), compare); for(i=0; i<m; i++) { scanf("%lld %lld", &d, &b); sum = 0; j = 0; while(j < n) { currentCut = high[j] + LL(a[j]) * (d - prevD[j]) - b; if(currentCut <= 0) { // if b is higher than the current grass - grasses are from highest to lowest // then sum remains break; } high[j] = b; prevD[j] = d; sum += currentCut; j++; }; // otherwise: if b is higher than the higher grass // then sum remains 0 printf("%lld\n", sum); } return 0; } |
English