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>
#pragma GCC optimize("O3")
#define endl '\n'
using namespace std;
const int maxn = 5e5 + 3;
int n, q;
string s;
void read()
{
cin >> n >> s >> q;
}
struct node
{
int to_delete, sum, min_suffix;
node() {}
node(int to_delete, int sum, int min_suffix)
{
this->to_delete = to_delete;
this->sum = sum;
this->min_suffix = min_suffix;
}
};
int get_min(vector <pair <int, int> > &v)
{
int ans = 0;
for (auto i: v)
ans = min(ans, i.second);
return ans;
}
vector <node> tr[maxn * 4];
void build(int v, int l, int r)
{
int len = r - l + 1;
tr[v].resize(len + 1);
vector <pair <int, int> > st;
st.push_back({r + 1, 0});
int balance = 0;
for (int i = r; i >= l; i--)
{
if (s[i-1] == 'C')
balance++;
else
balance--;
if (balance < st.back().second)
st.push_back({i, balance});
}
reverse (st.begin(), st.end());
int min_prefix = 0, idx = -1;
balance = 0;
for (int i = l; i <= r; i++)
{
if (s[i-1] == 'C')
balance++;
else
balance--;
if (balance < min_prefix)
min_prefix = balance, idx = i;
}
vector <int> to_delete;
for (int i = l; i <= idx; i++)
if (s[i-1] == 'T')
to_delete.push_back(i);
for (int i = len; i >= 0; i--)
{
if (i + min_prefix >= 0)
{
tr[v][i] = node(0, balance, get_min(st));
continue;
}
for (auto &j: st)
if (j.first <= to_delete.back())
j.second++;
to_delete.pop_back();
balance++;
tr[v][i] = node(-(i + min_prefix), balance, get_min(st));
}
if (l == r)
return;
int mid = (l + r) / 2;
build(v * 2, l, mid);
build(v * 2 + 1, mid + 1, r);
}
vector <int> curr;
void get(int v, int l, int r, int ll, int rr)
{
if (l > rr || r < ll)
return;
if (l >= ll && r <= rr)
{
curr.push_back(v);
return;
}
int mid = (l + r) / 2;
get (v * 2, l, mid, ll, rr);
get (v * 2 + 1, mid + 1, r, ll, rr);
}
void solve()
{
build(1, 1, n);
while (q--)
{
int l, r;
cin >> l >> r;
curr.clear();
get(1, 1, n, l, r);
int ans = 0;
int balance = 0;
vector <pair <int, int> > v;
for (auto i: curr)
{
auto temp = tr[i][min((int)tr[i].size(), balance)];
ans += temp.to_delete;
balance += temp.sum;
v.push_back({temp.sum, temp.min_suffix});
}
balance = 0;
int to_add = 0;
for (int i = (int)v.size() - 1; i >= 0; i--)
{
to_add = min(to_add, balance + v[i].second);
balance += v[i].first;
}
cout << ans - to_add << endl;
}
}
int main()
{
ios_base::sync_with_stdio(false);
cin.tie(nullptr);
cout.tie(nullptr);
read();
solve();
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |