This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define pii pair<int, int>
#define pll pair<ll, ll>
#define ff first
#define ss second
#define pb push_back
#define SZ(x) ((int)(x).size())
#define all(x) x.begin(), x.end()
#define debug(x) cout << #x << ": " << x << " "
#define nl cout << "\n"
#define rep(i, a, b) for(int i = (a); i < (b); i++)
#define per(i, a, b) for(int i = (a); i >= (b); i--)
mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
void save_to_floppy(const string &bits);
void read_array(int subtask_id, const vector<int> &a) {
stack<int> st;
string bits = "";
int N = SZ(a);
per(i, N - 1, 0){
while(!st.empty() && a[i] >= a[st.top()]){
st.pop(); bits += '0';
}
st.push(i);
bits += '1';
}
save_to_floppy(bits);
}
const int MAXK = 20+5;
const int MAXN = 5e5+100;
int nxt[MAXK][MAXN];
vector<int> solve_queries(int subtask_id, int N, const string &bits, const vector<int> &QL, const vector<int> &QR){
stack<int> st;
int j = 0;
per(i, N - 1, 0){
while(!st.empty() && bits[j] == '0'){
st.pop(); j++;
}
if(!st.empty()){
nxt[0][i] = st.top();
} else{
nxt[0][i] = i;
}
st.push(i); j++;
}
rep(k, 0, MAXK - 1){
rep(i, 0, N){
nxt[k + 1][i] = nxt[k][nxt[k][i]];
}
}
int Q = SZ(QL);
vector<int> ans(Q);
rep(q, 0, Q){
int l = QL[q], r = QR[q];
per(k, MAXK - 1, 0) if(nxt[k][l] <= r) l = nxt[k][l];
ans[q] = l;
}
return ans;
}
Compilation message (stderr)
stub.cpp: In function 'void run2()':
stub.cpp:101:30: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
101 | if (query_answers.size() != M) {
| ~~~~~~~~~~~~~~~~~~~~~^~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |