제출 #397941

#제출 시각아이디문제언어결과실행 시간메모리
397941VictorGlobal Warming (CEOI18_glo)C++17
10 / 100
48 ms3768 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]; cin >> n >> x; vi subseq; rep(i, 0, n) cin >> temps[i]; subseq.assign(n, 0); int longest = 0; per(i, 0, n) { int temp = -temps[i]; int idx = lower_bound(subseq.begin(), subseq.begin() + longest, temp) - subseq.begin(); subseq[idx] = temp; if (idx == longest) ++longest; ans = longest; } 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...