답안 #865729

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
865729 2023-10-24T14:53:39 Z vjudge1 Meteors (POI11_met) C++
74 / 100
3108 ms 59956 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 =  3e5+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;
}
# 결과 실행 시간 메모리 Grader output
1 Correct 9 ms 37464 KB Output is correct
2 Correct 10 ms 37720 KB Output is correct
3 Correct 10 ms 37556 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 10 ms 37464 KB Output is correct
2 Correct 10 ms 37468 KB Output is correct
3 Correct 10 ms 37660 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 299 ms 38816 KB Output is correct
2 Correct 330 ms 41728 KB Output is correct
3 Correct 331 ms 40912 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 298 ms 40220 KB Output is correct
2 Correct 304 ms 40020 KB Output is correct
3 Correct 329 ms 41992 KB Output is correct
4 Correct 73 ms 40276 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 156 ms 39220 KB Output is correct
2 Correct 204 ms 42252 KB Output is correct
3 Correct 140 ms 37464 KB Output is correct
4 Correct 320 ms 41428 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 298 ms 38072 KB Output is correct
2 Correct 277 ms 39968 KB Output is correct
3 Correct 291 ms 38700 KB Output is correct
4 Correct 332 ms 43452 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 2815 ms 59956 KB Output is correct
2 Incorrect 1533 ms 40808 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 3108 ms 58136 KB Output is correct
2 Incorrect 1052 ms 40804 KB Output isn't correct
3 Halted 0 ms 0 KB -