Submission #760261

#TimeUsernameProblemLanguageResultExecution timeMemory
760261danikoynovSequence (APIO23_sequence)C++17
28 / 100
2069 ms35496 KiB
#include "sequence.h" #include <bits/stdc++.h> using namespace std; const int maxn = 5e5 + 10; vector < int > occ[maxn]; int val[maxn], pref[maxn]; int sequence(int N, vector<int> A) { A.insert(A.begin(), 0); for (int i = 1; i <= N; i ++) occ[A[i]].push_back(i); int ans = 0; for (int x = 1; x <= N; x ++) { for (int i = 1; i <= N; i ++) { if (A[i] < x) val[i] = -1; else if (A[i] == x) val[i] = 0; else val[i] = 1; pref[i] = pref[i - 1] + val[i]; } for (int i = 0; i < occ[x].size(); i ++) { int j = i + ans; if (j >= occ[x].size()) break; //cout << "-----------" << endl; //cout << x << " " << i << " " << j << " " << ans << endl; ///cout << pref[r] << endl; int l = occ[x][i], r = occ[x][j]; int min_lf = 1e9, max_lf = -1e9; int min_rf = 1e9, max_rf = -1e9; int d = 0; for (int p = l - 1; p >= 0; p --) { if (A[p] == x) d ++; min_lf = min(min_lf, pref[p] - d); max_lf = max(max_lf, pref[p] + d); } d = 0; for (int p = r; p <= N; p ++) { if (A[p] == x && p != r) d ++; min_rf = min(min_rf, pref[p] - d); max_rf = max(max_rf, pref[p] + d); } max_rf += (j - i + 1); min_rf -= (j - i + 1); //cout << min_lf << " " << max_lf << " " << min_rf << " " << max_rf << endl; if (max(min_rf, min_lf) <= min(max_rf, max_lf)) { ///cout << x << " " << i << " " << j << endl; ans ++; i --; } } } return ans; }

Compilation message (stderr)

sequence.cpp: In function 'int sequence(int, std::vector<int>)':
sequence.cpp:31:27: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   31 |         for (int i = 0; i < occ[x].size(); i ++)
      |                         ~~^~~~~~~~~~~~~~~
sequence.cpp:34:19: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   34 |             if (j >= occ[x].size())
      |                 ~~^~~~~~~~~~~~~~~~
#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...