답안 #986771

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
986771 2024-05-21T08:04:09 Z emad234 벽 (IOI14_wall) C++17
0 / 100
118 ms 262144 KB
#pragma once
#include "bits/stdc++.h"
#define F first
#define S second
#define ll long long
#define pii pair<int,int>
const int mxN = (1 << 20);
const int mod = 1e9 + 7;
const int inf = INT_MAX;
using namespace std;
struct event{
    int ty,op,id,val;
};
queue<event>q[mxN];
pii seg[mxN];
int N,s,e;
pii combine(pii a,pii b){
    pii c;
    c.F = min(max(b.F,a.F),b.S);

    c.S = max(min(a.S,b.S),c.F);
    return c;
}
pii query(int l,int r,int ind){
    if(l > e || r < s) return {0,inf};
    if(l >= s && r <= e) return seg[ind];
    int md = (l + r) / 2;
    return combine(query(l,md,ind * 2),query(md + 1,r,ind * 2 + 1));
}
void update(int ind,int id,int val){
    ind += N;
    if(id == 1) seg[ind].F = val;
    else seg[ind].S = val;
    while(ind /= 2) seg[ind] = combine(seg[ind * 2],seg[ind * 2 + 1]);
}
void printseg(){
    int ex = 1;
    for(int i = 1;i < N * 2;i++){
        cout<<"{ "<<seg[i].F<<" , ";
        if(seg[i].S == inf) cout<<"inf";
        else cout<<seg[i].S;
        cout<<" } ";
        if(ex * 2 - 1 == i){
            ex *= 2;
            cout<<'\n';
        }
    }
}
void buildWall(int n, int k, int op[], int left[], int right[], int height[], int finalHeight[]){
    N = exp2(ceil(log2(n)));
    for(int i = 1;i <= N * 2;i++){
        seg[i] = {0,inf};
    }
    for(int i = 0;i < k;i++){
        q[left[i]].push({1,op[i],i,height[i]});
        q[right[i] + 1].push({-1,op[i],i,height[i]});
    }
    s = 1,e = n;
    for(int i = 0;i < n;i++){
        while(q[i].size()){
            auto u = q[i].front();
            q[i].pop();
            if(u.ty == -1){
                update(u.id,1 ,{0});
                update(u.id,2, {inf});
            }else{
                if(u.op == 1)
                    update(u.id,1,{u.val});
                else
                    update(u.id,2,{u.val});
            }
        }
        // printseg();
        finalHeight[i] = query(1,N,1).F;
    }


}

Compilation message

wall.cpp:1:9: warning: #pragma once in main file
    1 | #pragma once
      |         ^~~~
# 결과 실행 시간 메모리 Grader output
1 Runtime error 118 ms 262144 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 108 ms 262144 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 115 ms 262144 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 106 ms 262144 KB Execution killed with signal 9
2 Halted 0 ms 0 KB -