二分检验+差分
#include <iostream>
using namespace std;
const int maxn = 1000010;
int n, m;
long long arr[maxn];//每天借多少个教室
long long arr2[maxn];//教室差分
struct Node {
long long num;
int beginDay;
int endDay;
}dingdan[maxn];
bool judge(int num) {
for (int i = 0; i < maxn; i++) {
arr2[i] = 0;
}
int sum = 0;
for (int i = 1; i <= num; i++) {
arr2[dingdan[i].beginDay] += dingdan[i].num;
arr2[dingdan[i].endDay + 1] -= dingdan[i].num;
}
for (int i = 1; i <= n; i++) {
sum += arr2[i];
if (sum > arr[i])return false;
}
return true;
}
int find(int l, int r) {
while (l < r) {
int mid = (r - l) / 2 + l;
if (judge(mid))l = mid + 1;
else r = mid;
}
return l;
}
int main()
{
cin >> n >> m;
for (int i = 1; i <= n; i++) {
cin >> arr[i];
}
for (int i = 1; i <= m; i++) {
cin >> dingdan[i].num >> dingdan[i].beginDay >> dingdan[i].endDay;
}
if (find(1, m) < m) {
cout << "-1" << endl << find(1, m);
}
else {
cout << "0";
}
}


京公网安备 11010502036488号