[NOIP2012 提高组] 借教室

题意

学校在n天内每天有ai个教室可以租借,现在有m个订单,每个订单需要在第si天至第ti天租借di个教室,现在按顺序处理订单,判断能否满足所有订单,若不行,求第几个订单开始不满足

解题思路:

1.要让区间减去某个值,可以构造差分数组来处理
2.求第几个订单开始不满足,满足二分解答适用的情况

代码如下:

#include <bits/stdc++.h>
#include<algorithm>
using namespace std;
#define ll long long
#define N 1000005
ll a[N],b[N];
struct P {
    int d, x, y;
}p[N];
int n, m;
bool check(int mid) {
    memset(b, 0, sizeof(b));
    //差分来保存区间的减少值
    for (int j = 1; j <= mid; j++) {
        b[p[j].x] -= p[j].d;b[p[j].y+1]+=p[j].d;
    }
    for (int i = 1; i <= n; i++) {
        b[i] += b[i - 1];
        if (a[i]+b[i] < 0)return 1;
    }
    return 0;
}
int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    cin >> n >> m;
    for (int i = 1; i <= n; i++)cin >> a[i];
    for (int j = 1; j <= m; j++) {
        cin >> p[j].d >> p[j].x >> p[j].y;
    }
    //二分满足到第几个订单
    int l = 1, r = m+1;
    while (l < r) {
        int mid = l + r >> 1;
        if (check(mid))r = mid;
        else l = mid + 1;
    }
    if (l == m + 1)cout << 0;
    else cout << -1 << "\n" << l;
}


posted @   mark0  阅读(60)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示