제출 #788562

#제출 시각아이디문제언어결과실행 시간메모리
788562antonFinancial Report (JOI21_financial)C++17
5 / 100
896 ms63396 KiB
#include<bits/stdc++.h> using namespace std; #define int long long #define pii pair<int, int> const int INF = (1LL<<61LL) -1LL; int n, q, d; struct MaxTree{ vector<int> tree; vector<int> d; vector<bool> act; MaxTree(vector<int>&v){ int m =1; while(m<v.size()){ m*=2; } m*=2; tree.resize(m); d.resize(m); act.resize(m, false); build(v, 0, v.size()-1, 1); } void build(vector<int>& v, int lt, int rt, int t){ if(rt ==lt){ tree[t] = v[lt]; d[t] = v[lt]; } else{ int mid = (lt+rt)/2; build(v, lt, mid, t*2); build(v, mid+1, rt, t*2+1); tree[t] = max(tree[t*2], tree[t*2+1]); } } void push(int t, int lt, int rt){ if(act[t] && lt!=rt){ d[t*2] =d[t]; d[t*2+1] =d[t]; tree[t*2] = d[t]; tree[t*2+1] = d[t]; act[t*2] = true; act[t*2+1] = true; act[t] = false; } } void update(int l, int r, int v, int lt, int rt, int t){ if(l<=lt && rt<=r){ d[t] = v; tree[t] = v; } else if(r<lt || rt<l){ return; } else{ int mid = (lt+rt)/2; push(t, lt, rt); update(l, r, v, lt, mid, t*2); update(l, r, v, mid+1, rt, t*2+1); tree[t] = max(tree[t*2], tree[t*2+1]); } } int get(int l, int r, int lt, int rt, int t){ //cout<<lt<<" "<<rt<<" "<<tree[t]<<endl; if(l<=lt && rt<=r){ return tree[t]; } else if(rt<l|| r<lt){ return -INF; } else{ int mid = (lt+rt)/2; push(t, lt, rt); return max(get(l, r, lt, mid, t*2), get(l, r, mid+1, rt, t*2+1)); } } }; vector<pii> oc; signed main(){ cin>>n>>d; vector<int> v(n); for(int i = 0; i<n; i++){ cin>>v[i]; } vector<int> big(n); map<int, int> small; for(int i = 0; i<n; i++){ cin>>v[i]; big[i] = v[i]; } set<int> big2(big.begin(), big.end()); big.assign(big2.begin(), big2.end()); for(int i = 0; i<big.size(); i++){ small.insert(pii(big[i], i)); //cout<<big[i]<<endl; } auto ref = vector<int>(big.size(), -1); MaxTree max_tr = MaxTree(ref); deque<pii> rem; int bs =big.size(); for(int i = 0; i<n; i++){ oc.clear(); if(rem.size()>0 && rem.front().first<i-d){ //cout<<"removing date "<<set_tr.tree[1]<<endl; //cout<<"i "<<i<<" removing "<<rem[0].second<<endl; if(rem.size()==1){ max_tr.update(0, bs-1, 0, 0, bs-1, 1); } else{ max_tr.update(0, rem[1].second-1, 0, 0, bs-1, 1); } rem.pop_front(); } //cout<<"i: "<<i+1<<" "<<max(1LL, max_tr.get(0, small[v[i]]-1, 0, bs-1, 1)+1)<<endl; max_tr.update(small[v[i]], small[v[i]], max(1LL, max_tr.get(0, small[v[i]]-1, 0, bs-1, 1)+1), 0, bs-1, 1); while(rem.size()>0 && rem.front().second>=small[v[i]]){ rem.pop_back(); } rem.push_back(pii(i, small[v[i]])); } cout<<max_tr.get(0, bs-1, 0, bs-1, 1)<<endl; }

컴파일 시 표준 에러 (stderr) 메시지

Main.cpp: In constructor 'MaxTree::MaxTree(std::vector<long long int>&)':
Main.cpp:18:16: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   18 |         while(m<v.size()){
      |               ~^~~~~~~~~
Main.cpp: In function 'int main()':
Main.cpp:105:21: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::vector<long long int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  105 |     for(int i = 0; i<big.size(); i++){
      |                    ~^~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...