Submission #1149589

#TimeUsernameProblemLanguageResultExecution timeMemory
1149589vladiliusBitaro, who Leaps through Time (JOI19_timeleap)C++20
4 / 100
3092 ms7024 KiB
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
using pii = pair<int, int>;
#define pb push_back
#define ff first
#define ss second

struct DS{
    int n;
    vector<int> l, r;
    DS(int ns){
        n = ns;
        l.resize(n);
        r.resize(n);
    }
    void upd(int p, int s, int e){
        l[p] = s; r[p] = e;
    }
    ll get(int a, int b, int c, int d){
        ll out = 0;
        for (int i = a; i < c; i++){
            b = max(b, l[i]);
            if (b < r[i]){
                b++;
            }
            else {
                out += (b - r[i] + 1);
                b = r[i];
            }
        }
        if (b > d) out += (b - d);
        return out;
    }
};

int main(){
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    
    int n, q; cin>>n>>q;
    vector<int> l(n), r(n);
    for (int i = 1; i < n; i++){
        cin>>l[i]>>r[i];
    }
    
    DS T1(n), T2(n);
    for (int i = 1; i < n; i++){
        T1.upd(i, l[i], r[i]);
        T2.upd(n - i, l[i], r[i]);
    }
    
    while (q--){
        int t; cin>>t;
        if (t == 1){
            int p, s, e; cin>>p>>s>>e;
            T1.upd(p, s, e);
            T2.upd(n - p, s, e);
        }
        else {
            int a, b, c, d; cin>>a>>b>>c>>d;
            if (a <= c){
                cout<<T1.get(a, b, c, d)<<"\n";
            }
            else {
                cout<<T2.get(n - a + 1, b, n - c + 1, d)<<"\n";
            }
        }
    }
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...