結果
問題 | No.318 学学学学学 |
ユーザー | nikutto_ |
提出日時 | 2019-02-20 11:35:10 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 198 ms / 2,000 ms |
コード長 | 5,395 bytes |
コンパイル時間 | 1,975 ms |
コンパイル使用メモリ | 181,412 KB |
実行使用メモリ | 18,176 KB |
最終ジャッジ日時 | 2024-06-22 18:48:57 |
合計ジャッジ時間 | 6,071 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 14 ms
6,816 KB |
testcase_01 | AC | 28 ms
6,940 KB |
testcase_02 | AC | 38 ms
6,944 KB |
testcase_03 | AC | 21 ms
6,940 KB |
testcase_04 | AC | 29 ms
6,940 KB |
testcase_05 | AC | 191 ms
18,176 KB |
testcase_06 | AC | 197 ms
12,544 KB |
testcase_07 | AC | 160 ms
10,752 KB |
testcase_08 | AC | 130 ms
10,112 KB |
testcase_09 | AC | 119 ms
9,088 KB |
testcase_10 | AC | 92 ms
7,808 KB |
testcase_11 | AC | 198 ms
18,176 KB |
testcase_12 | AC | 134 ms
12,672 KB |
testcase_13 | AC | 116 ms
10,752 KB |
testcase_14 | AC | 102 ms
9,728 KB |
testcase_15 | AC | 91 ms
8,704 KB |
testcase_16 | AC | 77 ms
7,680 KB |
testcase_17 | AC | 114 ms
12,672 KB |
testcase_18 | AC | 103 ms
12,672 KB |
testcase_19 | AC | 117 ms
12,544 KB |
testcase_20 | AC | 61 ms
7,680 KB |
testcase_21 | AC | 2 ms
6,944 KB |
testcase_22 | AC | 1 ms
6,944 KB |
testcase_23 | AC | 2 ms
6,944 KB |
testcase_24 | AC | 2 ms
6,940 KB |
testcase_25 | AC | 2 ms
6,940 KB |
testcase_26 | AC | 2 ms
6,940 KB |
testcase_27 | AC | 2 ms
6,940 KB |
testcase_28 | AC | 2 ms
6,940 KB |
ソースコード
#include<bits/stdc++.h> namespace ProconLib{ template<typename update_t,typename value_t> class LazySegmentTree{ public: using UpdateMerger=std::function<update_t(update_t,update_t)>; using ValueMerger=std::function<value_t(value_t,value_t)>; using Evaluator=std::function<value_t(value_t,update_t)>; private: int N; const value_t E; UpdateMerger mergeU; ValueMerger mergeV; Evaluator eval; std::vector<value_t> dat; std::vector<update_t> lazy; std::vector<int> flag; void propagate(int node); void applyLazy(int node,update_t x); void updateImpl(int l,int r,int k,int lb,int ub,update_t f); value_t queryImpl(int l,int r,int k,int lb,int ub); value_t getValue(int node){return flag[node] ? eval(dat[node],lazy[node]) : dat[node];} public: LazySegmentTree(int N,Evaluator eval,UpdateMerger mergeU,ValueMerger mergeV,value_t E); void update(int l,int r,update_t f); void update(int pos,value_t x); value_t query(int a,int b); void debug(){ int p=1; int idx=0; std::cerr<<"#dat info"<<std::endl; while(idx<2*N-1){ for(int i=0;i<p;i++) std::cerr<<dat[idx++]<<" "; std::cerr<<"\n"; p*=2; } p=1; idx=0; std::cerr<<"#lazy info"<<std::endl; while(idx<2*N-1){ for(int i=0;i<p;i++) std::cerr<<lazy[idx++]<<" "; std::cerr<<"\n"; p*=2; } } }; template<typename update_t,typename value_t> LazySegmentTree<update_t,value_t>::LazySegmentTree(int N,Evaluator eval,UpdateMerger mergeU,ValueMerger mergeV,value_t E):mergeU(mergeU),mergeV(mergeV),eval(eval),E(E){ this->N=1; while(this->N<N) this->N*=2; dat.assign(this->N*2-1,E); lazy.assign(this->N*2-1,update_t()); flag.assign(this->N*2-1,false); } /* template<typename update_t,typename value_t> LazySegmentTree<update_t,value_t>:: */ template<typename update_t,typename value_t> void LazySegmentTree<update_t,value_t>::propagate(int node){ if(flag[node]){ flag[node]=false; applyLazy(node*2+1,lazy[node]); applyLazy(node*2+2,lazy[node]); dat[node]=mergeV(getValue(node*2+1),getValue(node*2+2)); } } template<typename update_t,typename value_t> void LazySegmentTree<update_t,value_t>::applyLazy(int node,update_t x){ if(flag[node]){ lazy[node]=mergeU(lazy[node],x); } else{ flag[node]=true; lazy[node]=x; } } template<typename update_t,typename value_t> void LazySegmentTree<update_t,value_t>::updateImpl(int l,int r,int k,int lb,int ub,update_t x){ if(r<=lb || ub<=l) return; if(l<=lb && ub<=r){ applyLazy(k,x); return; } propagate(k); int mid=(lb+ub)/2; updateImpl(l,r,k*2+1,lb,mid,x); updateImpl(l,r,k*2+2,mid,ub,x); dat[k]=mergeV(getValue(k*2+1),getValue(k*2+2)); } template<typename update_t,typename value_t> value_t LazySegmentTree<update_t,value_t>::queryImpl(int l,int r,int k,int lb,int ub){ if(r<=lb || ub<=l) return E; if(l<=lb && ub<=r){ return getValue(k); } propagate(k); int mid=(lb+ub)/2; value_t lhs=queryImpl(l,r,k*2+1,lb,mid); value_t rhs=queryImpl(l,r,k*2+2,mid,ub); return mergeV(lhs,rhs); } template<typename update_t,typename value_t> void LazySegmentTree<update_t,value_t>::update(int l,int r,update_t x){ updateImpl(l,r,0,0,N,x); } template<typename update_t,typename value_t> void LazySegmentTree<update_t,value_t>::update(int pos,value_t x){ pos+=N-1; std::stack<int> st; int p=pos; while(p>0){ int par=(p-1)/2; st.push(par); p=par; } while(!st.empty()){ int p=st.top(); st.pop(); propagate(p); } flag[pos]=false; dat[pos]=x; while(pos>0){ int par=(pos-1)/2; dat[par]=mergeV(getValue(par*2+1),getValue(par*2+2)); pos=par; } } template<typename update_t,typename value_t> value_t LazySegmentTree<update_t,value_t>::query(int l,int r){ return queryImpl(l,r,0,0,N); } }; //verify(yukicoder No,318) using namespace std; using namespace ProconLib; int paste(int x,int y){ return y; } int mymax(int x,int y){ return max(x,y); } int main(){ int n; cin>>n; vector<int> a(n); for(int i=0;i<n;i++) cin>>a[i]; map<int,vector<int>> mp; for(int i=0;i<n;i++) mp[a[i]].push_back(i); LazySegmentTree<int,int> seg(n,paste,paste,mymax,0); for(auto &e:mp){ int tar=e.first; vector<int>& vec=e.second; if(vec.empty()) continue; seg.update(vec[0],vec.back()+1,tar); } vector<int> b(n); for(int i=0;i<n;i++) b[i]=seg.query(i,i+1); for(int i=0;i<n;i++){ cout<<b[i]<<(i+1==n ? "\n" : " "); } return 0; }