莫名RE,求调
查看原帖
莫名RE,求调
760406
tunecoming楼主2024/10/15 14:52

下载的数据本地可以跑出来,但是交上去就RE。
求调

#include <bits/stdc++.h>
using namespace std;
#define int long long
#define lowbit(x) ((x) & - (x))
#define ull unsigned long long

const int INF = 0x3f3f3f3f3f3f3f3fLL;
const int N = 2e5 + 5;

struct node {
    int op, l, r, c, id;
} q[N], q1[N], q2[N];

int a[N];
int ans[N];

int tree[N << 2];
int tag[N << 2];

int ls(int p) {return p << 1;}
int rs(int p) {return p << 1 | 1;}

int n;

int push_up(int p) {
    tree[p] = tree[ls(p)] + tree[rs(p)];
}

void addtag(int p, int l, int r, int d) {
    tree[p] += d * (r - l + 1);
    tag[p] += d;
}

void push_down(int p, int l, int r) {
    if (tag[p]) {
        int mid = (l + r) >> 1;
        addtag(ls(p), l, mid, tag[p]);
        addtag(rs(p), mid + 1, r, tag[p]);
        tag[p] = 0;
    }
}

void update(int L, int R, int p, int l, int r, int d) {
    if (L <= l && r <= R) {
        addtag(p, l, r, d);
        return ;   
    }
    push_down(p, l, r);
    int mid = (l + r) >> 1;
    if (L <= mid)
        update(L, R, ls(p), l, mid, d);
    if (mid < R)
        update(L, R, rs(p), mid + 1, r, d);
    push_up(p);
}

int query(int L, int R, int p, int l, int r) {
    if (L <= l && r <= R) {
        return tree[p];
    }
    push_down(p, l, r);
    int res = 0;
    int mid = (l + r) >> 1;
    if (L <= mid)
        res += query(L, R, ls(p), l, mid);
    if (mid < R)
        res += query(L, R, rs(p), mid + 1, r);   
    return res;
}

void work(int L, int R, int l, int r) {
    if (L > R)
        return ;
    if (l == r) {
        for (int i = L; i <= R; i++) {
            if (q[i].op == 2) {
                ans[q[i].id] = l - n - 1;
            }
        }
        return ;
    }
    
    int mid = (l + r + 1) >> 1;
    int cnt1 = 0, cnt2 = 0;
    for (int i = L; i <= R; i++) {
        if (q[i].op == 1) {
            if (q[i].c >= mid) {
                update(q[i].l, q[i].r, 1, 1, n, 1);
                q2[++cnt2] = q[i];
            } else {
                q1[++cnt1] = q[i];
            }
        } else {
            int x = query(q[i].l, q[i].r, 1, 1, n);
            if (q[i].c <= x) {
                q2[++cnt2] = q[i];
            } else {
                q[i].c -= x;
                q1[++cnt1] = q[i];
            }
        }
    }

    for (int i = 1; i <= cnt2; i++) {
        if (q2[i].op == 1) {
            update(q2[i].l, q2[i].r, 1, 1, n, -1);
        }
    }

    for (int i = 1; i <= cnt1; i++) {
        q[L + i - 1] = q1[i];
    }
    for (int i = 1; i <= cnt2; i++) {
        q[L + cnt1 + i - 1] = q2[i];
    }

    work(L, L + cnt1 - 1, l, mid - 1);
    work(L + cnt1, R, mid, r);
}

void solve() {
    int m;
    cin >> n >> m;
    for (int i = 1; i <= m; i++) {
        ans[i] = -INF;
    }
    int cnt = 0;
    for (int i = 1; i <= m; i++) {
        int op, l, r, c;
        cin >> op >> l >> r >> c;
        if (op == 1)
            c += n + 1;
        q[++cnt] = {op, l, r, c, i};
    }
    work(1, cnt, 1, 2 * n + 1);

    for (int i = 1; i <= m; i++) {
        if (ans[i] != -INF) {
            cout << ans[i] << '\n';
        }
    }
    // cout << "Debug!\n";
    return ;
}

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);

    int t = 1;
    // cin >> t;

    while (t--)
        solve();
    return 0;
} 
2024/10/15 14:52
加载中...