| 시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
|---|---|---|---|---|---|
| 3 초 | 1024 MB | 12 | 8 | 8 | 72.727% |
재현이는 알파벳 대문자로만 이루어진 문자열 $S$를 하나 가지고 있다. 이 문자열 중 일부를 잘라 종우에게 선물을 주려고 한다. 종우는 선물 받은 문자열에 다음 과정을 통해 문자열을 MATKOR로 만들고 싶다.
A는 B로, B는 C로 바꿀 수 있다. Z에는 이 연산을 적용할 수 없다.MATKOR로 만들어야 한다.재현이는 문자열 $S=s_1s_2s_3\cdots s_{\lvert S\rvert}$의 일부를 잘라 종우에게 선물해주려 한다. 재현이는 아래 쿼리에 대한 답을 알고자 한다. 아래 쿼리에서 $i$와 $j$는 1ドル$ 이상 $\lvert S\rvert$이하의 정수, $c$는 대문자 알파벳이다.
MATKOR로 만드는 방법의 수와 각 방법당 총 연산 횟수의 분산을 구한다. 문자별로 적용된 연산의 종류와 횟수가 같다면 같은 방법이다.이때 분산이란, 가능한 모든 서로 다른 연산 방법에 대한, 연산 사용 횟수에서 연산 사용 횟수의 평균을 뺀 값의 제곱의 평균을 의미한다. 조금 더 엄밀하게 말하자면 모든 가능한 연산 방법의 집합을 $T,ドル 연산 방법 $P$에서 연산을 사용한 횟수를 $|P|$라고 할 때 분산은 다음과 같이 계산할 수 있다.
$$\frac{1}{\lvert T\rvert } \sum_{P \in T} \left(\lvert P\rvert- \frac{1}{\lvert T \rvert} \sum_{Q \in T} \lvert Q \rvert \right)^2$$
첫 번째 줄에 대문자 알파벳으로 구성된 문자열 $S(6\le\lvert S\rvert\le 100,円 000)$가 주어진다.
두 번째 줄에 쿼리의 수 $Q(1\le Q\le 100,円 000)$가 주어진다.
세 번째 줄부터 $Q$줄에 걸쳐 다음 두 쿼리 중 하나가 주어진다. 쿼리 2ドル$는 적어도 한 번 이상 주어진다.
쿼리 2ドル$가 주어질 때마다 쿼리의 답인 방법의 수와 분산을 한 줄에 공백으로 구분하여 출력한다.
단, 답이 매우 커질 수 있으므로 10ドル^9+7$으로 나눈 나머지를 출력한다. 또한 해당 쿼리의 방법의 수를 10ドル^9+7$으로 나눈 나머지가 0ドル$이라면 분산은 출력하지 않는다.
기약 분수 $\frac{p}{q}(p\ge 0,q>0,\gcd(p,q) =1)$를 $M$으로 나눈 나머지는 $q^{-1}$가 $q\cdot q^{-1}\equiv 1\pmod M$을 만족하는 정수, 즉 $q$의 $M$에 대한 모듈로 곱셈 역원일 때, $p\cdot q^{-1}\pmod M$로 정의한다. 만약 정수일 경우 $q=q^{-1}=1$이므로 $p\pmod M$를 의미한다.
방법의 수를 10ドル^9+7$로 나눈 나머지가 0ドル$이 아니라면 분산이 정수 혹은 분모가 10ドル^9+7$의 배수가 아닌 유리수로 나타내어짐을 증명할 수 있다.
| 번호 | 배점 | 제한 |
|---|---|---|
| 1 | 11 | $Q=1$; 주어지는 쿼리는 2ドル$ 1ドル$ $\lvert S \rvert$ |
| 2 | 89 | 추가적인 제한 조건 없음 |
MATKOQR 5 2 1 7 1 6 N 2 1 7 2 1 6 2 2 7
2 250000002 3 888888898 1 0 0
첫 번째 쿼리에서 종우가 선물 받는 문자열은 $A=$MATKOQR이며 다음과 같이 두 가지 방법이 존재한다.
따라서 방법의 수는 2ドル$이며, 연산 횟수의 평균이 $\frac{3}{2}$이므로, 분산은 $\frac{1}{2}\left( \left( 1-\frac{3}{2} \right)^2+\left( 2-\frac{3}{2} \right)^2 \right) =\frac{1}{4}$이다.
두 번째 쿼리에서 재현이가 가진 문자열이 $S=$MATKONR로 변경된다.
세 번째 쿼리에서 종우가 선물 받는 문자열은 $A=$MATKONR이며 다음과 같이 세 가지 방법이 존재한다.
따라서 방법의 수는 3ドル$이며, 연산 횟수의 평균이 $\frac{8}{3}$이므로, 분산은 $\frac{1}{3}\left( \left( 2-\frac{8}{3} \right)^2+\left( 1-\frac{8}{3} \right)^2+\left( 5-\frac{8}{3} \right)^2 \right) =\frac{26}{9}$이다.
네 번째 쿼리에서 종우가 선물 받는 문자열은 $A=$MATKON이며 다음과 같이 한 가지 방법이 존재한다.
따라서 방법의 수는 1ドル$이며, 연산 횟수의 평균이 4ドル$이므로, 분산은 $\frac{1}{1}\left( 4-4 \right)^2=0$이다.
다섯 번째 쿼리에서 종우가 선물 받는 문자열은 $A=$ATKONR이며 어떤 연산을 해도 두 번째 문자를 A로 만들 수 없어 방법의 수는 0ドル$이다.
LMATKOR 4 2 2 7 2 1 7 1 1 K 2 1 7
1 0 2 250000002 2 1
BABCEFGH 5 2 1 6 2 2 7 2 1 8 1 2 B 2 1 8
1 0 0 15 755555568 0
University > 고려대학교 > MatKor Cup > 제5회 고려대학교 MatKor Cup: 2024 Summer/Fall F번