| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 2 초 | 1024 MB | 206 | 84 | 76 | 51.351% |
Easy 버전과 $N,ドル $Q$의 제한을 제외한 문제 차이는 없다.
다음 조건들을 만족하는 부분 문자열을 알파벳 묶음이라고 하자.
예를 들어 "AAABBAAC"와 같은 문자열이 있을 때, 알파벳 묶음은 "AAA", "BB", "AA", "C"로 4개다. 위의 문자열에서 "B", "AC"는 조건을 만족하지 않으므로 알파벳 묶음이 아니다.
영어 알파벳 대문자로만 이루어진 길이가 $N$인 문자열 $S = S_1 S_2 \dots S_N$가 주어질 때, 다음 쿼리를 수행하는 프로그램을 작성하자.
Z인 경우 A로 변경한다.$S_l S_{l+1} \dots S_r$는 $S$의 $l$번째 알파벳부터 $r$번째 알파벳까지를 모두 순서대로 포함하는 부분 문자열이다.
첫 번째 줄에 문자열의 길이 $N$과 쿼리의 개수 $Q$가 공백으로 구분되어 주어진다. $(3 \leq N, Q \leq 200 \ 000)$
두 번째 줄에 영어 알파벳 대문자로만 이루어진 길이가 $N$인 문자열 $S$가 주어진다.
세 번째 줄부터 $Q$개의 줄에 걸쳐 쿼리가 한 줄에 하나씩 주어진다. $(1 \leq l \leq r \leq N)$
1ドル$번 쿼리는 한 번 이상 주어진다.
1ドル$번 쿼리에 대한 결괏값을 한 줄에 하나씩 입력으로 주어진 순서대로 출력한다.
8 5 AAABBAAC 1 3 8 2 2 7 1 1 8 2 6 7 1 1 8
4 5 3
예제의 각 2ドル$번 쿼리를 수행할 때마다 문자열 $S$는 다음과 같이 바뀐다.
ABBCCBBCABBCCCCCUniversity > 국민대학교 > KPSC Welcome Contest 2024 > Open Contest J번