답안 #1019340

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1019340 2024-07-10T17:51:51 Z ttamx Pyramid Base (IOI08_pyramid_base) C++17
100 / 100
4221 ms 145620 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];

namespace SUB2{

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(int l,int r,int i){
        t[i]=0,lz[i]=0;
        if(l==r)return;
        int m=(l+r)/2;
        build(l,m,i*2);
        build(m+1,r,i*2+1);
    }
    void build(){
        build(1,n,1);
    }
    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();
    for(int i=1;i<k;i++)for(auto [l,r,v]:add[i])seg.update(l,r+k-1,v);
    for(int i=k;i<=m;i++){
        for(auto [l,r,v]:add[i])seg.update(l,r+k-1,v);
        for(auto [l,r,v]:del[i-k])seg.update(l,r+k-1,-v);
        if(seg.query(k,n)<=b)return true;
    }
    return false;
}

inline void solve(){
    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;
}

}

namespace SUB3{

struct Block{
    int val,sz;
    bool operator<(const Block &b)const{
        return val<b.val||(val==b.val&&sz>b.sz);
    }
};

struct Info{
    int sz;
    Block mn,pre,suf;
    Info():sz(0),mn({INF,0}),pre({INF,0}),suf({INF,0}){}
    static Info single(){
        Info res;
        res.sz=1;
        res.mn=res.pre=res.suf={0,1};
        return res;
    }
    void apply(int v){
        mn.val+=v;
        pre.val+=v;
        suf.val+=v;
    }
    friend Info operator+(const Info &a,const Info &b){
        Info res;
        res.mn=min(a.mn,b.mn);
        if(a.suf.val==b.pre.val)res.mn=min(res.mn,{a.suf.val,a.suf.sz+b.pre.sz});
        res.pre=a.pre;
        if(a.pre.val==b.pre.val&&a.pre.sz==a.sz)res.pre.sz+=b.pre.sz;
        res.suf=b.suf;
        if(a.suf.val==b.suf.val&&b.suf.sz==b.sz)res.suf.sz+=a.suf.sz;
        res.sz=a.sz+b.sz;
        return res;
    }
};

struct SegTree{
    Info t[K];
    int lz[K];
    void apply(int i,int v){
        t[i].apply(v);
        lz[i]+=v;
    }
    void push(int i){
        apply(i*2,lz[i]);
        apply(i*2+1,lz[i]);
        lz[i]=0;
    }
    void pull(int i){
        t[i]=t[i*2]+t[i*2+1];
    }
    void build(int l,int r,int i){
        lz[i]=0;
        if(l==r)return t[i]=Info::single(),void();
        int m=(l+r)/2;
        build(l,m,i*2);
        build(m+1,r,i*2+1);
        pull(i);
    }
    void build(){
        build(1,n,1);
    }
    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);
        pull(i);
    }
    void update(int x,int y,int v){
        update(1,n,1,x,y,v);
    }
}seg;

inline void solve(){
    seg.build();
    int top=0,bot=0,ans=0;
    while(bot<=m){
        auto x=seg.t[1].mn;
        int h=bot-top,w=x.val==0?x.sz:0;
        ans=max(ans,min(h,w));
        if(h<=w){
            bot++;
            for(auto [l,r,v]:add[bot])seg.update(l,r,v);
        }else{
            top++;
            for(auto [l,r,v]:del[top])seg.update(l,r,-v);
        }
    }
    cout << ans << "\n";
}

}

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);
    }
    if(b>0)SUB2::solve();
    else SUB3::solve();
}
# 결과 실행 시간 메모리 Grader output
1 Correct 43 ms 104784 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 41 ms 104796 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 44 ms 104864 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 45 ms 105040 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 62 ms 105808 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 65 ms 113072 KB Output is correct
2 Correct 65 ms 113152 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 66 ms 113232 KB Output is correct
2 Correct 62 ms 113156 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 66 ms 105300 KB Output is correct
2 Correct 73 ms 105296 KB Output is correct
3 Correct 75 ms 105380 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 183 ms 108116 KB Output is correct
2 Correct 330 ms 108204 KB Output is correct
3 Correct 329 ms 108024 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 526 ms 122964 KB Output is correct
2 Correct 85 ms 106324 KB Output is correct
3 Correct 137 ms 122344 KB Output is correct
4 Correct 1175 ms 122964 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 944 ms 123472 KB Output is correct
2 Correct 3320 ms 123472 KB Output is correct
3 Correct 593 ms 123472 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 960 ms 124000 KB Output is correct
2 Correct 3497 ms 123636 KB Output is correct
3 Correct 3170 ms 123848 KB Output is correct
4 Correct 3784 ms 123856 KB Output is correct
5 Correct 4221 ms 123684 KB Output is correct
6 Correct 418 ms 123984 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 521 ms 130128 KB Output is correct
2 Correct 260 ms 117332 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 666 ms 138068 KB Output is correct
2 Correct 650 ms 134844 KB Output is correct
3 Correct 540 ms 129372 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 844 ms 145620 KB Output is correct
2 Correct 965 ms 143460 KB Output is correct
3 Correct 1018 ms 143296 KB Output is correct
4 Correct 808 ms 141752 KB Output is correct
5 Correct 656 ms 136888 KB Output is correct