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;
struct SparseTable {
vector<vector<int> > dp;
int query (int l, int r) {
int sz = log2(r - l + 1);
return dp[l][sz] | dp[r - (1 << sz) + 1][sz];
}
SparseTable (string s) {
int n = s.size();
dp.resize(n);
for (int i = 0; i < n; i++) {
dp[i].resize(32);
dp[i][0] = (1 << (s[i] - 'a'));
}
for (int j = 1; j <= 31; j++) {
for (int i = 0; i < n; i++) {
dp[i][j] = dp[i][j - 1] | dp[min((i + (1 << (j - 1))), n - 1)][j - 1];
}
}
}
};
bool f (pair<int,int> p1, pair<int,int> p2) {
return ((int64_t)p1.first * (int64_t)p2.second < (int64_t)p2.first * (int64_t)p1.second);
}
int main() {
int n;
cin >> n;
string s;
cin >> s;
SparseTable st(s);
pair<int,int> p = make_pair(n, 1);
pair<int,int> bounds;
for (int i = 0; i < s.size(); i++) {
for (int j = 1; j <= __builtin_popcount(st.query(i, (int)s.size() - 1)); j++) {
int l = i;
int r = s.size() - 1;
while (l != r) {
int m = (l + r)/2;
if (__builtin_popcount(st.query(i, m)) >= j) {
r = m;
} else {
l = m + 1;
}
}
pair<int,int> q = make_pair(j, l - i + 1);
if (f(q, p)) {
p = q;
bounds = make_pair(i, l);
}
//cout << l << ' ';
}
//cout << '\n';
}
cout << bounds.first + 1 << " " << bounds.second + 1 << '\n';
//cout << p.first + 1 << " " << p.second + 1 << '\n';
}
Compilation message (stderr)
nivelle.cpp: In function 'int main()':
nivelle.cpp:34:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
34 | for (int i = 0; i < s.size(); i++) {
| ~~^~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |