Submission #865730

# Submission time Handle Problem Language Result Execution time Memory
865730 2023-10-24T14:53:52 Z vjudge1 Meteors (POI11_met) C++
74 / 100
1911 ms 65536 KB
// Bolatulu
#include <bits/stdc++.h>

typedef long long ll;
typedef unsigned long long ull;
typedef double db;
#define int long long
#define kanagattandirilmagandiktarinizdan ios_base::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
#define pb push_back
#define F first
#define S second
#define md (tl+tr)/2
#define TL v+v,tl,md
#define TR v+v+1,md+1,tr

#pragma GCC target( "sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")
#pragma GCC optimize("Ofast,unroll-loops,fast-math,O3")

using namespace std;

int binpow(int a,int n,int M) {
    if (n==0)
        return 1;
    if (n%2!=0)
        return (a * binpow(a,n-1,M))%M;
    int z=binpow(a,n/2,M);
    return (z*z)%M;
}

const ll INF = 1e18;
const int N =  4e5+7;
const int M = 1e9+7;
const ll HZ = 1e5;
const int MAX = INT_MAX;
const int MIN = INT_MIN;
const db pi = 3.141592653;
const int P=31;

struct segment{int l;int r;};

int n,m,q,a[N],p[N],t[4*N];
segment seg[N];
vector <int> MID[N];

void push(int v) {
    t[v+v]+=t[v], t[v+v+1]+=t[v];
    t[v]=0;
}

void upd(int l,int r,int val,int v=1,int tl=1,int tr=m) {
    if (tl>=l and tr<=r) {
        t[v]+=val;
        return;
    }
    if (tl>r or tr<l)
        return;
    push(v);
    upd(l,r,val,TL), upd(l,r,val,TR);
}

int get(int pos,int v=1,int tl=1,int tr=m) {
    if (tl==tr)
        return t[v];
    push(v);
    if (pos<=md)
        return get(pos,TL);
    else
        return get(pos,TR);
}

int l[N],r[N],v[N];
vector <int> pos[N];

void solve() {
    cin >> n >> m;
    for (int i=1;i<=m;i++)
        cin >> a[i], pos[a[i]].push_back(i);
    for (int i=1;i<=n;i++)
        cin >> p[i];
    cin >> q;
    for (int i=1;i<=q;i++)
        cin >> l[i] >> r[i] >> v[i];
    for (int i=1;i<=n;i++)
        seg[i].l=-1,seg[i].r=q+1;
    bool ok=true;
    while (ok) {
        for (int i=0;i<=q;i++)
            MID[i].clear();
        for (int i=0;i<=4*N-1;i++)
            t[i]=0;
        ok=false;
        for (int i=1;i<=n;i++) {
            // cout << seg[i].l << ' ' << seg[i].r << endl;
            if (seg[i].l+1<seg[i].r) {
                int mid = (seg[i].l + seg[i].r) / 2;
                MID[mid].push_back(i);
                ok=true;
            }
        }
        // cout << endl;
        for (int i=0;i<=q;i++) {
            if (i>0) {
                if (l[i] > r[i])
                    upd(l[i], m, v[i]), upd(1, r[i], v[i]);
                else
                    upd(l[i], r[i], v[i]);
            }
            for (auto now : MID[i]) {
                int sum=0;
                for (auto now1 : pos[now])
                    sum+=get(now1);
                if (sum>=p[now])
                    seg[now].r=i;
                else
                    seg[now].l=i;
            }
        }
    }
    for (int i=1;i<=n;i++) {
        if (seg[i].r==q+1)
            cout << "NIE\n";
        else
            cout << seg[i].r << '\n';
    }
}

signed main() {
    // freopen("lca.in", "r", stdin);
    // freopen("lca.out", "w", stdout);
    kanagattandirilmagandiktarinizdan
    int test = 1, count = 1;
    // cin >> test;
    while (test--) {
        // cout << "Case " << count << ":\n";
        solve();
        if (test)
            // cout << '\n';
            count++;
    }
    return 0;
}
# Verdict Execution time Memory Grader output
1 Correct 17 ms 41564 KB Output is correct
2 Correct 15 ms 41564 KB Output is correct
3 Correct 14 ms 41564 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 14 ms 41564 KB Output is correct
2 Correct 13 ms 41560 KB Output is correct
3 Correct 15 ms 41564 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 297 ms 43036 KB Output is correct
2 Correct 359 ms 45824 KB Output is correct
3 Correct 354 ms 44884 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 309 ms 44328 KB Output is correct
2 Correct 307 ms 44216 KB Output is correct
3 Correct 366 ms 46092 KB Output is correct
4 Correct 83 ms 44380 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 170 ms 43412 KB Output is correct
2 Correct 209 ms 46352 KB Output is correct
3 Correct 138 ms 41724 KB Output is correct
4 Correct 328 ms 45540 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 301 ms 42196 KB Output is correct
2 Correct 282 ms 44236 KB Output is correct
3 Correct 301 ms 42700 KB Output is correct
4 Correct 351 ms 47300 KB Output is correct
# Verdict Execution time Memory Grader output
1 Runtime error 1635 ms 65536 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Runtime error 1911 ms 65536 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -