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 <iostream>
#include <algorithm>
#include <vector>
#include <map>
#include <queue>
#include <set>
#include <unordered_map>
#include <unordered_set>
#include <string>
#include <string.h>
#include <bitset>
#include <numeric>
#include <utility>
#define fr(i, n, m) for(int i = (n); i <= (m); i ++)
#define pb push_back
#define st first
#define nd second
#define pq priority_queue
#define all(x) begin(x), end(x)
using namespace std;
typedef long long ll;
typedef long double ld;
typedef pair<int,int> pii;
const int mxn = 2e5;
const ll mod = 998244353;
const ll inf = 1e18;
int n;
string s;
int pref[mxn];
int suff[mxn];
pair<int,int> q_prefix(int l, int r){
    int mi = 0;
    int id = l-1;
    for(int i = l; i <= r; i ++){
        if(pref[i] - pref[l-1] < mi){
            mi = pref[i] - pref[l-1];
            id = i;
        }
    }
    return {abs(mi),id};
}
pair<int,int> q_suffix(int l, int r){
    int mi = 0;
    int id = r+1;
    for(int i = r; i >= l; i --){
        if(suff[i] - suff[r+1] < mi){
            mi = suff[i] - suff[r+1];
            id = i;
        }
    }
    return {abs(mi), id};
}
int solve(int l, int r){
    int RET = 0;
    
    pii A = q_prefix(l, r);
    pii B = q_suffix(l, r);
    
    if(A.st == 0) return B.st;
    if(B.st == 0) return A.st;
    
    if(A.nd < B.nd){
        return A.st + B.st;
    }
    
    pii L = q_prefix(l, B.nd-1);
    pii R = q_suffix(A.nd+1, r);
    
    RET = A.st + R.st;
//    cout<<"here : "<<RET<<" "<<L.st<<" " <<R.st<<endl;
    int init_sum_l = pref[l-1];
    int init_sum_r = suff[r+1];
    
    int MIN = 1e9;
//    cout<<init_sum_l<<endl;
    
    int max_height = pref[B.nd-1];
    fr(i, B.nd, A.nd){
//        cout<<pref[i]<<' ';
        MIN = min(MIN, (pref[i] + L.st));
            // (init_sum_l - MIN) how much should we increase MIN to get above given 0 - init_sum_l
        max_height = max(max_height, (pref[i] + L.st) + (init_sum_l - MIN));
    }
//    cout<<endl;
//    cout<<max_height<<endl;
    int offset = max_height - init_sum_l;
    
    
    int min_point = suff[A.nd+1] + R.st - offset;
    RET += max(0, init_sum_r - min_point);
    
    return RET;
}
int main(){
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);
    cin >> n;
    cin >> s;
    
    
    for(int i = 1; i <= n; i ++){
        pref[i] = pref[i-1];
        if(s[i-1] == 'C') pref[i] += 1;
        if(s[i-1] == 'T') pref[i] -= 1;
    }
    for(int i = n; i >= 1; i --){
        suff[i] = suff[i+1];
        if(s[i-1] == 'C') suff[i] += 1;
        if(s[i-1] == 'T') suff[i] -= 1;
    }
    int Q;
    cin >> Q;
    fr(i, 1, Q){
        int l, r;
        cin >> l >> r;
        cout<<solve(l, r)<<endl;
    }
    return 0;
}
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... | 
| # | Verdict | Execution time | Memory | Grader output | 
|---|
| Fetching results... |