이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
// author: erray
#include <bits/stdc++.h>
#ifdef DEBUG
#include "debug.h"
#else
#define debug(...) void(37)
#endif
using namespace std;
struct F {
int t, b;
F(int _t, int _b) : t(_t), b(_b) { }
bool operator<(F ot) {
return t * ot.b < ot.t * b;
}
};
int main() {
ios_base::sync_with_stdio(false);
cin.tie(0);
int N;
string S;
cin >> N >> S;
constexpr int A = 26;
vector<array<int, A>> next(N + 1);
for (int i = 0; i < A; ++i) {
next[N][i] = N;
}
for (int i = N - 1; i >= 0; --i) {
next[i] = next[i + 1];
next[i][S[i] - 'a'] = i;
}
debug(next);
F mn(2, 1);
int ans_L = -1, ans_R = -1;
for (int i = 0; i < N; ++i) {
array<bool, A> in{};
int size = 0;
int r = i;
while (r < N) {
int go = N;
int l = -1;
for (int j = 0; j < A; ++j) {
if (!in[j] && next[r][j] < go) {
go = next[r][j];
l = j;
}
}
debug(size, i, go);
F me(size, go - i);
if (size > 0 && me < mn) {
swap(mn, me);
ans_L = i;
ans_R = go;
}
r = go;
if (l != -1) {
in[l] = true;
}
size += 1;
}
}
cout << ans_L + 1 << ' ' << ans_R << '\n';
}
# | 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... |