Submission #864211

#TimeUsernameProblemLanguageResultExecution timeMemory
864211vjudge1Financial Report (JOI21_financial)C++17
5 / 100
46 ms8044 KiB
/* DK ORZ! */ #include "iostream" #include "cstdio" #include "cstdlib" #include "algorithm" #include "cmath" #include "vector" #include "set" #include "map" #include "unordered_set" #include "unordered_map" #include "queue" #include "ctime" #include "random" #include "cassert" #include "complex" #include "string" #include "cstring" #include "chrono" #include "bitset" #include "array" #include "stack" #define endl '\n' #define all(x) x.begin(), x.end() #define int long long using namespace std; const int mod = 998244353; const int nax = 300000; int n, D; vector <int> a; void D1(){ int mx = 0, res = 0; for (int i = 0; i < n; i++){ if (a[i] > mx){ mx = a[i]; res++; } } cout << res << endl; } void DN(){ vector <int> LIS; LIS.push_back(a[0]); for (int i = 1; i < n; i++){ if (a[i] > LIS.back()){ LIS.push_back(a[i]); }else{ int ind = lower_bound(all(LIS), a[i]) - LIS.begin(); LIS[ind] = a[i]; } } cout << (int)LIS.size() << endl; } void Glup(){ } void Smart(){ } void solve(){ cin >> n >> D; a.resize(n); for (int i = 0; i < n; i++){ cin >> a[i]; } if (D == 1)D1(); else if (D == n)DN(); else if (n <= 7000)Glup(); else Smart(); } signed main(){ ios::sync_with_stdio(0); cin.tie(0); int tt = 1; //cin >> tt; while (tt--){ solve(); } 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...