제출 #369508

#제출 시각아이디문제언어결과실행 시간메모리
369508denkendoemeerBubble Sort 2 (JOI18_bubblesort2)C++14
100 / 100
3136 ms53576 KiB
#include<bits/stdc++.h>
#include "bubblesort2.h"
#define ll long long
using namespace std;
int val[1000005],aint[4000005],lazy[4000005];
vector<pair<int,int>>aux;
int n,q,l;
void push(int nod,int st,int dr)
{
    if (lazy[nod]){
        aint[nod]+=lazy[nod];
        if (st!=dr){
            lazy[nod*2]+=lazy[nod];
            lazy[nod*2+1]+=lazy[nod];
        }
        lazy[nod]=0;
    }
}
void update(int nod,int st,int dr,int l,int r,int add)
{
    if (l>r)
        return ;
    if (l<=st && dr<=r){
        aint[nod]+=add;
        if (st!=dr){
            lazy[nod*2]+=add;
            lazy[nod*2+1]+=add;
        }
        return ;
    }
    push(nod,st,dr);
    int mij=(st+dr)/2;
    if (l<=mij)
        update(nod*2,st,mij,l,r,add);
    if (mij+1<=r)
        update(nod*2+1,mij+1,dr,l,r,add);
    push(nod*2,st,mij);
    push(nod*2+1,mij+1,dr);
    aint[nod]=max(aint[nod*2],aint[nod*2+1]);
}
void update2(int nod,int st,int dr,int poz,int val)
{
    if (st==dr){
        aint[nod]+=val;
        return ;
    }
    push(nod,st,dr);
    int mij=(st+dr)/2;
    if (poz<=mij)
        update2(nod*2,st,mij,poz,val);
    else
        update2(nod*2+1,mij+1,dr,poz,val);
    push(nod*2,st,mij);
    push(nod*2+1,mij+1,dr);
    aint[nod]=max(aint[nod*2],aint[nod*2+1]);
}
int calcpoz(pair<int,int>auxi)
{
    return lower_bound(aux.begin(),aux.end(),auxi)-aux.begin();
}
vector<int> countScans(vector<int>a,vector<int>x,vector<int>v)
{
    n=a.size();
    q=x.size();
    int i;
    for(i=0;i<n;i++)
        aux.push_back(make_pair(a[i],i));
    for(i=0;i<q;i++)
        aux.push_back(make_pair(v[i],x[i]));
    sort(aux.begin(),aux.end());
    aux.resize(unique(aux.begin(),aux.end())-aux.begin());
    for(i=0;i<n;i++){
        int ind1=calcpoz(make_pair(a[i],i));
        update(1,0,aux.size()-1,ind1,ind1,(i+1));
		int ind2=calcpoz(make_pair(a[i],-1));
		update(1,0,aux.size()-1,ind2,aux.size()-1,-1);
    }
    vector<int>ans;
    for(i=0;i<q;i++){
        int ind1=calcpoz(make_pair(a[x[i]],x[i]));
        update(1,0,aux.size()-1,ind1,ind1,-(x[i]+1));
		int ind2=calcpoz(make_pair(a[x[i]],-1));
		update(1,0,aux.size()-1,ind2,aux.size()-1,1);
        a[x[i]]=v[i];
        ind1=calcpoz(make_pair(a[x[i]],x[i]));
        update(1,0,aux.size()-1,ind1,ind1,(x[i]+1));
		ind2=calcpoz(make_pair(a[x[i]],-1));
		update(1,0,aux.size()-1,ind2,aux.size()-1,-1);
        ans.push_back(aint[1]);
    }
    return ans;
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...