Submission #469128

#TimeUsernameProblemLanguageResultExecution timeMemory
469128Vladth11Financial Report (JOI21_financial)C++14
0 / 100
332 ms407768 KiB
#include <bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> #include <ext/pb_ds/tree_policy.hpp> #define debug(x) cerr << #x << " " << x << "\n" #define debugs(x) cerr << #x << " " << x << " " #pragma GCC optimize("Ofast,unroll-loops") using namespace std; using namespace __gnu_pbds; typedef long long ll; typedef pair <ll, ll> pii; typedef pair <long double, pii> muchie; typedef tree <ll, null_type, less_equal <ll>, rb_tree_tag, tree_order_statistics_node_update> OST; const ll NMAX = 600001; const ll INF = (1LL << 60); const ll HALF = (1LL << 59); const ll MOD = 30013; const ll BLOCK = 318; const ll base = 31; const ll nr_of_bits = 21; int dp[NMAX]; int v[NMAX]; map <int, int> mp; int n; class AINT{ public: deque <pii> a[NMAX]; int aint[NMAX * 4]; void update(int node, int st, int dr, int poz, pii x){ if(st == dr){ while(a[st].size() && a[st].back().first <= x.first) a[st].pop_back(); a[st].push_back(x); aint[node] = a[st].front().first; return; } int mid = (st + dr) / 2; if(poz <= mid){ update(node * 2, st, mid, poz, x); }else{ update(node * 2 + 1, mid + 1, dr, poz, x); } aint[node] = max(aint[node * 2], aint[node * 2 + 1]); } void sterge(int node, int st, int dr, int poz, int x){ if(st == dr){ while(a[st].size() && a[st].front().second < x) a[st].pop_front(); if(a[st].size()) aint[node] = a[st].front().first; else aint[node] = 0; return; } int mid = (st + dr) / 2; if(poz <= mid){ sterge(node * 2, st, mid, poz, x); }else{ sterge(node * 2 + 1, mid + 1, dr, poz, x); } aint[node] = max(aint[node * 2], aint[node * 2 + 1]); } int query(int node, int st, int dr, int a, int b){ if(a <= st && dr <= b){ return aint[node]; } int mid = (st + dr) / 2; int maxim = 0; if(a <= mid){ maxim = max(maxim, query(node * 2, st, mid, a, b)); } if(b > mid){ maxim = max(maxim, query(node * 2 + 1, mid + 1, dr, a, b)); } return maxim; } void insert(int poz, pii x){ update(1, 1, NMAX - 1, poz, x); } void erase(int poz, int upd){ sterge(1, 1, NMAX - 1, poz, upd); } }aint; int nrm[NMAX]; int main() { ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); int i, d; cin >> n >> d; for(i = 1; i <= n; i++){ cin >> v[i]; nrm[i] = v[i]; } sort(v + 1, v + n + 1); int cnt = 0; for(i = 1; i <= n; i++){ if(i == 1 || v[i] != v[i - 1]) cnt++; mp[v[i]] = cnt; } for(i = 1; i <= n; i++){ v[i] = nrm[i]; v[i] = mp[v[i]]; } int maxim = 0; /// de incercat normalizarea mai rapid for(i = 1; i <= n; i++){ dp[i] = 1; if(i > 1 && v[i - 1] < v[i]) dp[i] = dp[i - 1] + 1; if(i > 2 && v[i - 2] < v[i]) dp[i] = max(dp[i], dp[i - 2] + 1); } for(i = n; i >= n - 1; i--){ maxim = max(maxim, dp[i]); } cout << maxim; return 0; }
#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...