답안 #1019139

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1019139 2024-07-10T14:05:45 Z ttamx Pyramid Base (IOI08_pyramid_base) C++17
90 / 100
5000 ms 84956 KB
#include<bits/stdc++.h>

using namespace std;

const int N=1e6+5;
const int K=1<<21;
const int INF=INT_MAX/2;

int n,m,b,p;
vector<tuple<int,int,int>> add[N],del[N];

struct SegTree{
    int t[K],lz[K];
    void apply(int i,int v){
        t[i]+=v,lz[i]+=v;
    }
    void push(int i){
        apply(i*2,lz[i]);
        apply(i*2+1,lz[i]);
        lz[i]=0;
    }
    void build(){
        for(int i=0;i<K;i++)t[i]=lz[i]=0;
    }
    void update(int l,int r,int i,int x,int y,int v){
        if(y<l||r<x)return;
        if(x<=l&&r<=y)return apply(i,v);
        int m=(l+r)/2;
        push(i);
        update(l,m,i*2,x,y,v);
        update(m+1,r,i*2+1,x,y,v);
        t[i]=min(t[i*2],t[i*2+1]);
    }
    void update(int x,int y,int v){
        update(1,n,1,x,y,v);
    }
    int query(int l,int r,int i,int x,int y){
        if(y<l||r<x)return INF;
        if(x<=l&&r<=y)return t[i];
        int m=(l+r)/2;
        push(i);
        return min(query(l,m,i*2,x,y),query(m+1,r,i*2+1,x,y));
    }
    int query(int x,int y){
        return query(1,n,1,x,y);
    }
}seg;

bool check(int k){
    seg.build();
    seg.update(1,k-1,INF);
    for(int i=1;i<k;i++)for(auto [l,r,v]:add[i])seg.update(max(l,k),r+k-1,v);
    for(int i=k;i<=m;i++){
        for(auto [l,r,v]:add[i])seg.update(max(l,k),r+k-1,v);
        for(auto [l,r,v]:del[i-k])seg.update(max(l,k),r+k-1,-v);
        if(seg.t[1]<=b)return true;
    }
    return false;
}

int main(){
    cin.tie(nullptr)->sync_with_stdio(false);
    cin >> m >> n >> b >> p;
    for(int i=0;i<p;i++){
        int x1,y1,x2,y2,c;
        cin >> x1 >> y1 >> x2 >> y2 >> c;
        add[x1].emplace_back(y1,y2,c);
        del[x2].emplace_back(y1,y2,c);
    }
    int l=0,r=min(n,m);
    while(l<r){
        int m=(l+r+1)/2;
        if(check(m))l=m;
        else r=m-1;
    }
    cout << l;
}
# 결과 실행 시간 메모리 Grader output
1 Correct 31 ms 63572 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 30 ms 63568 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 43 ms 63768 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 35 ms 63832 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 47 ms 63740 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 83 ms 63872 KB Output is correct
2 Correct 120 ms 63832 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 143 ms 63876 KB Output is correct
2 Correct 98 ms 64336 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 41 ms 63824 KB Output is correct
2 Correct 61 ms 63952 KB Output is correct
3 Correct 54 ms 63832 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 120 ms 64688 KB Output is correct
2 Correct 204 ms 64424 KB Output is correct
3 Correct 175 ms 64624 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 224 ms 65056 KB Output is correct
2 Correct 57 ms 64848 KB Output is correct
3 Correct 95 ms 64592 KB Output is correct
4 Correct 294 ms 64848 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 335 ms 65364 KB Output is correct
2 Correct 586 ms 65108 KB Output is correct
3 Correct 203 ms 65104 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 310 ms 65600 KB Output is correct
2 Correct 794 ms 65556 KB Output is correct
3 Correct 647 ms 65528 KB Output is correct
4 Correct 731 ms 65524 KB Output is correct
5 Correct 745 ms 65380 KB Output is correct
6 Correct 199 ms 65656 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 2903 ms 75088 KB Output is correct
2 Correct 457 ms 70084 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4791 ms 80276 KB Output is correct
2 Correct 4964 ms 77648 KB Output is correct
3 Correct 1559 ms 72316 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 4827 ms 84956 KB Output is correct
2 Execution timed out 5068 ms 83136 KB Time limit exceeded
3 Halted 0 ms 0 KB -