제출 #397952

#제출 시각아이디문제언어결과실행 시간메모리
397952VictorGlobal Warming (CEOI18_glo)C++17
100 / 100
70 ms6152 KiB
#include <bits/stdc++.h> using namespace std; #define rep(i, a, b) for (int i = a; i < (b); ++i) #define per(i, a, b) for (int i = b - 1; i >= (a); --i) #define trav(a, x) for (auto &a : x) #define all(x) x.begin(), x.end() #define sz(x) x.size() #define pb push_back #define umap unordered_map #define uset unordered_set typedef pair<int, int> ii; typedef pair<int, ii> iii; typedef vector<int> vi; typedef vector<ii> vii; typedef vector<vi> vvi; typedef long long ll; const int INF = 1000000007; int main() { cin.tie(0)->sync_with_stdio(0); cin.exceptions(cin.failbit); int n, x, ans = 0, temps[200001], pos[200001], val[200001]; cin >> n >> x; vi subseq(n), revseq; revseq = subseq; rep(i, 0, n) cin >> temps[i]; int longest = 0, revlong = 0; per(i, 0, n) { int temp = -temps[i]; int idx = lower_bound(revseq.begin(), revseq.begin() + revlong, temp) - revseq.begin(); pos[i] = idx; val[i] = revseq[idx]; revseq[idx] = temp; if (idx == revlong) ++revlong; } ans = revlong; rep(i, 0, n) { int temp = temps[i] - x; int idx = lower_bound(subseq.begin(), subseq.begin() + longest, temp) - subseq.begin(); subseq[idx] = temp; if (idx == longest) ++longest; revseq[pos[i]] = val[i]; if (!val[i]) --revlong; temp = -temp; int revidx = lower_bound(revseq.begin(), revseq.begin() + revlong, temp) - revseq.begin(); ans=max(ans,idx+revidx+1); } cout << ans << endl; 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...
#Verdict Execution timeMemoryGrader output
Fetching results...