시간 제한메모리 제한제출정답맞힌 사람정답 비율
2 초 (하단 참고)512 MB113483350.769%

문제

Albert는 길이가 $n$인 길다란 케이크를 구웠다. 이 케익은 $n$등분 할 수 있도록 총 $n$개의 칸으로 미리 나눠져있고, 일부 칸에는 과일 토핑이 올려져있다.

예를 들어 아래 그림은 $n = 8$인 케이크이고 $0$은 토핑이 없는 칸, $1$은 과일 토핑이 있는 칸을 나타낸다. 이를 정수 배열로 나타내면 $A = [0, 1, 1, 0, 0, 1, 1, 0]$로 표현할 수 있다. 구체적으로, $A[i]$는 $i$번째 칸에 토핑이 있으면 $1$, 없으면 $0$이다.

Albert는 이 케이크를 정확히 $k-1$번 잘라 $k$개의 조각으로 나누고 싶은데, 아래 조건을 만족하도록 자르고 싶다:

  • 조건 1: 각 케이크 조각에 포함된 토핑이 올라간 칸의 개수가 모두 동일해야한다.
  • 조건 2: 버려지는 칸이나 조각이 생겨서는 안된다.

예를 들어 $k = 2$ 인 경우 버려지는 칸이나 조각 없이 위 케이크를 자를 수 있는 방법은 총 $7$가지 존재한다. 그 중 조건 1을 만족하는 경우는 아래와 같이 세 가지 방법이다. 각 케이크 조각에는 토핑이 올라간 칸이 두 개씩 있다.

다른 예로, 아래 그림은 $n = 5$, $A = [0, 1, 0, 1, 0]$, $k = 2$인 경우 위 조건들을 만족하면서 케이크를 자를 수 있는 두 가지 방법을 나타낸다.

입력으로 $n$, $k$, 그리고 토핑의 유무를 나타내는 배열 $A$가 주어졌을 때, 조건을 만족하며 케이크를 자를 수 있는 방법이 총 몇 가지 있는지 구해보자. 단, 답이 매우 클 수 있으므로 $10^9+7$ 로 나눈 나머지를 출력한다.

입력

첫 줄에 테스트 케이스의 수 $T$가 주어진다.

각 테스트 케이스는 두 줄에 나누어 주어진다. 첫 줄에 $n$과 $k$가 공백으로 구분되어 주어진다. 둘째 줄에 배열 $A$의 값이 주어지는데, 공백없이 길이 $n$인 문자열 형태로 주어진다.

출력

각 테스트 케이스의 정답을 각 줄에 출력한다.

제한

  • $1 ≤ T ≤ 10$
  • $1 ≤ k ≤ n ≤ 1\,000\,000$

예제 입력 1

9
1 1
1
5 1
01010
5 2
01010
5 3
01010
8 2
01100110
14 2
00100100100100
13 3
0111010100100
61 21
1001001001001001001001001001001001001001001001001001001001001
3 2
000

예제 출력 1

1
1
2
0
3
3
2
486784380
2

예제 1: 케이크 길이가 $1$이며 이를 한 조각으로 나누는 방법은 한 가지이다 (이 때 케이크는 $0$회 자른다).

예제 2: 예제 1과 마찬가지로 $k = 1$인 경우 답은 $1$이다.

예제 3: [01][010][010][10]의 두 가지 방법으로 조건을 만족하며 케이크를 자를 수 있다.

예제 4: 토핑이 올라간 칸이 $2$칸이지만 $k = 3$이므로 조건 2를 만족하는 방법은 없다.

예제 5: 본문에서 다루었다.

예제 8: 조건을 만족하며 케이크를 자를 수 있는 방법의 수는 $3\,486\,784\,401$이지만 $10^9+7$ 로 나눈 나머지를 출력해야 함에 유의하자.

예제 9: 케이크 위에 토핑이 하나도 없을 수도 있다.

[{"problem_id":"25334","problem_lang":"0","title":"\uae34 \ucf00\uc774\ud06c \ub098\ub220\uc8fc\uae30","description":"<p>Albert\ub294 \uae38\uc774\uac00 $n$\uc778 \uae38\ub2e4\ub780 \ucf00\uc774\ud06c\ub97c \uad6c\uc6e0\ub2e4. \uc774 \ucf00\uc775\uc740 $n$\ub4f1\ubd84 \ud560 \uc218 \uc788\ub3c4\ub85d \ucd1d $n$\uac1c\uc758 \uce78\uc73c\ub85c \ubbf8\ub9ac \ub098\ub220\uc838\uc788\uace0, \uc77c\ubd80 \uce78\uc5d0\ub294 \uacfc\uc77c \ud1a0\ud551\uc774 \uc62c\ub824\uc838\uc788\ub2e4.<\/p>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4 \uc544\ub798 \uadf8\ub9bc\uc740 $n = 8$\uc778 \ucf00\uc774\ud06c\uc774\uace0 $0$\uc740 \ud1a0\ud551\uc774 \uc5c6\ub294 \uce78, $1$\uc740 \uacfc\uc77c \ud1a0\ud551\uc774 \uc788\ub294 \uce78\uc744 \ub098\ud0c0\ub0b8\ub2e4. \uc774\ub97c \uc815\uc218 \ubc30\uc5f4\ub85c \ub098\ud0c0\ub0b4\uba74 $A = [0, 1, 1, 0, 0, 1, 1, 0]$\ub85c \ud45c\ud604\ud560 \uc218 \uc788\ub2e4. \uad6c\uccb4\uc801\uc73c\ub85c, $A[i]$\ub294 $i$\ubc88\uc9f8 \uce78\uc5d0 \ud1a0\ud551\uc774 \uc788\uc73c\uba74 $1$, \uc5c6\uc73c\uba74 $0$\uc774\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/eb27b42b-56af-4262-b272-8b4e80816b07\/-\/preview\/\" style=\"width: 400px;\" \/><\/p>\r\n\r\n<p>Albert\ub294 \uc774 \ucf00\uc774\ud06c\ub97c \uc815\ud655\ud788 $k-1$\ubc88 \uc798\ub77c $k$\uac1c\uc758 \uc870\uac01\uc73c\ub85c \ub098\ub204\uace0 \uc2f6\uc740\ub370, \uc544\ub798 \uc870\uac74\uc744 \ub9cc\uc871\ud558\ub3c4\ub85d \uc790\ub974\uace0 \uc2f6\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>\uc870\uac74 1: \uac01 \ucf00\uc774\ud06c \uc870\uac01\uc5d0 \ud3ec\ud568\ub41c \ud1a0\ud551\uc774 \uc62c\ub77c\uac04 \uce78\uc758 \uac1c\uc218\uac00 \ubaa8\ub450 \ub3d9\uc77c\ud574\uc57c\ud55c\ub2e4.<\/li>\r\n\t<li>\uc870\uac74 2: \ubc84\ub824\uc9c0\ub294 \uce78\uc774\ub098 \uc870\uac01\uc774 \uc0dd\uaca8\uc11c\ub294 \uc548\ub41c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4 $k = 2$ \uc778 \uacbd\uc6b0 \ubc84\ub824\uc9c0\ub294 \uce78\uc774\ub098 \uc870\uac01 \uc5c6\uc774 \uc704 \ucf00\uc774\ud06c\ub97c \uc790\ub97c \uc218 \uc788\ub294 \ubc29\ubc95\uc740 \ucd1d $7$\uac00\uc9c0 \uc874\uc7ac\ud55c\ub2e4. \uadf8 \uc911 \uc870\uac74 1\uc744 \ub9cc\uc871\ud558\ub294 \uacbd\uc6b0\ub294 \uc544\ub798\uc640 \uac19\uc774 \uc138 \uac00\uc9c0 \ubc29\ubc95\uc774\ub2e4. \uac01 \ucf00\uc774\ud06c \uc870\uac01\uc5d0\ub294 \ud1a0\ud551\uc774 \uc62c\ub77c\uac04 \uce78\uc774 \ub450 \uac1c\uc529 \uc788\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/49d5a282-4665-4571-b4ec-e692d66840cc\/-\/preview\/\" style=\"height: 60px; width: 400px;\" \/><\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/d2eb2dd6-1583-4978-8148-46b9383d91cb\/-\/preview\/\" style=\"height: 60px; width: 400px;\" \/><\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/530396df-cabc-4c62-ab79-f83d8c02effd\/-\/preview\/\" style=\"height: 58px; width: 400px;\" \/><\/p>\r\n\r\n<p>\ub2e4\ub978 \uc608\ub85c, \uc544\ub798 \uadf8\ub9bc\uc740 $n = 5$, $A = [0, 1, 0, 1, 0]$, $k = 2$\uc778 \uacbd\uc6b0 \uc704 \uc870\uac74\ub4e4\uc744 \ub9cc\uc871\ud558\uba74\uc11c \ucf00\uc774\ud06c\ub97c \uc790\ub97c \uc218 \uc788\ub294 \ub450 \uac00\uc9c0 \ubc29\ubc95\uc744 \ub098\ud0c0\ub0b8\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/73d42293-e2ac-4321-8624-e9658da5444d\/-\/preview\/\" style=\"height: 41px; width: 600px;\" \/><\/p>\r\n\r\n<p>\uc785\ub825\uc73c\ub85c $n$, $k$, \uadf8\ub9ac\uace0 \ud1a0\ud551\uc758 \uc720\ubb34\ub97c \ub098\ud0c0\ub0b4\ub294 \ubc30\uc5f4 $A$\uac00 \uc8fc\uc5b4\uc84c\uc744 \ub54c, \uc870\uac74\uc744 \ub9cc\uc871\ud558\uba70 \ucf00\uc774\ud06c\ub97c \uc790\ub97c \uc218 \uc788\ub294 \ubc29\ubc95\uc774 \ucd1d \uba87 \uac00\uc9c0 \uc788\ub294\uc9c0 \uad6c\ud574\ubcf4\uc790. \ub2e8, \ub2f5\uc774 \ub9e4\uc6b0 \ud074 \uc218 \uc788\uc73c\ubbc0\ub85c $10^9+7$ \ub85c \ub098\ub208 \ub098\uba38\uc9c0\ub97c \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","input":"<p>\uccab \uc904\uc5d0 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc218 $T$\uac00 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\ub294 \ub450 \uc904\uc5d0 \ub098\ub204\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4. \uccab \uc904\uc5d0 $n$\uacfc $k$\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4. \ub458\uc9f8 \uc904\uc5d0 \ubc30\uc5f4 $A$\uc758 \uac12\uc774 \uc8fc\uc5b4\uc9c0\ub294\ub370, \uacf5\ubc31\uc5c6\uc774 \uae38\uc774 $n$\uc778 \ubb38\uc790\uc5f4 \ud615\ud0dc\ub85c \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n","output":"<p>\uac01 \ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uc815\ub2f5\uc744 \uac01 \uc904\uc5d0 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"Korean","limit":"<ul>\r\n\t<li>$1 &le; T &le; 10$<\/li>\r\n\t<li>$1 &le; k &le; n &le; 1\\,000\\,000$<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>\uc608\uc81c 1: \ucf00\uc774\ud06c \uae38\uc774\uac00 $1$\uc774\uba70 \uc774\ub97c \ud55c \uc870\uac01\uc73c\ub85c \ub098\ub204\ub294 \ubc29\ubc95\uc740 \ud55c \uac00\uc9c0\uc774\ub2e4 (\uc774 \ub54c \ucf00\uc774\ud06c\ub294 $0$\ud68c \uc790\ub978\ub2e4).<\/p>\r\n\r\n<p>\uc608\uc81c 2: \uc608\uc81c 1\uacfc \ub9c8\ucc2c\uac00\uc9c0\ub85c $k = 1$\uc778 \uacbd\uc6b0 \ub2f5\uc740 $1$\uc774\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 3: <code>[01][010]<\/code>\uacfc <code>[010][10]<\/code>\uc758 \ub450 \uac00\uc9c0 \ubc29\ubc95\uc73c\ub85c \uc870\uac74\uc744 \ub9cc\uc871\ud558\uba70 \ucf00\uc774\ud06c\ub97c \uc790\ub97c \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 4: \ud1a0\ud551\uc774 \uc62c\ub77c\uac04 \uce78\uc774 $2$\uce78\uc774\uc9c0\ub9cc $k = 3$\uc774\ubbc0\ub85c \uc870\uac74 2\ub97c \ub9cc\uc871\ud558\ub294 \ubc29\ubc95\uc740 \uc5c6\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 5: \ubcf8\ubb38\uc5d0\uc11c \ub2e4\ub8e8\uc5c8\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 8: \uc870\uac74\uc744 \ub9cc\uc871\ud558\uba70 \ucf00\uc774\ud06c\ub97c \uc790\ub97c \uc218 \uc788\ub294 \ubc29\ubc95\uc758 \uc218\ub294 $3\\,486\\,784\\,401$\uc774\uc9c0\ub9cc $10^9+7$ \ub85c \ub098\ub208 \ub098\uba38\uc9c0\ub97c \ucd9c\ub825\ud574\uc57c \ud568\uc5d0 \uc720\uc758\ud558\uc790.<\/p>\r\n\r\n<p>\uc608\uc81c 9: \ucf00\uc774\ud06c \uc704\uc5d0 \ud1a0\ud551\uc774 \ud558\ub098\ub3c4 \uc5c6\uc744 \uc218\ub3c4 \uc788\ub2e4.<\/p>\r\n"},{"problem_id":"25334","problem_lang":"1","title":"Long Cake","description":"<p>Albert just baked a cake of length $n$. This cake is pre-divided into $n$ equal-size units, so that it can be divided into $n$ pieces and some of the units have fruit topping on top.<\/p>\r\n\r\n<p>For instance, the image below shows a cake of length $8$ where each unit with $0$ shows no toppings and with $1$ shows toppings. If it&#39;s represented as an integer array, it would be&nbsp;$A = [0, 1, 1, 0, 0, 1, 1, 0]$. Formally, $A[i]$ is $1$ if there is a topping on the $i$-th cake piece and $0$ otherwise.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/eb27b42b-56af-4262-b272-8b4e80816b07\/-\/preview\/\" style=\"width: 400px;\" \/><\/p>\r\n\r\n<p>Albert wants to cut this cake exactly $k-1$ times into $k$ pieces, while satisfying the following conditions:<\/p>\r\n\r\n<ul>\r\n\t<li>Condition 1: Each cake piece must contain the same number of units with toppings.<\/li>\r\n\t<li>Condition 2: No unit can be discarded or thrown away.<\/li>\r\n<\/ul>\r\n\r\n<p>For instance, when $k = 2$, there are $7$ different ways to cut the cake above into two pieces while satisfying Condition 2. Among those, there are there ways to also satisfy Condition 1. Each cake piece would have two units with toppings.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/49d5a282-4665-4571-b4ec-e692d66840cc\/-\/preview\/\" style=\"height: 60px; width: 400px;\" \/><\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/d2eb2dd6-1583-4978-8148-46b9383d91cb\/-\/preview\/\" style=\"height: 60px; width: 400px;\" \/><\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/530396df-cabc-4c62-ab79-f83d8c02effd\/-\/preview\/\" style=\"height: 58px; width: 400px;\" \/><\/p>\r\n\r\n<p>Consider a different example below where&nbsp;$n = 5$, $A = [0, 1, 0, 1, 0]$, and $k = 2$. There are two ways to satsify the two conditions.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/73d42293-e2ac-4321-8624-e9658da5444d\/-\/preview\/\" style=\"height: 41px; width: 600px;\" \/><\/p>\r\n\r\n<p>Given $n$, $k$, and the array $A$ that represents which units contain toppings, compute the number of ways to cut the cake while satisfying the said conditions.&nbsp;Since the answer can be large, output the answer modulo&nbsp;$10^9+7$.<\/p>\r\n","input":"<p>The first line of the input will contain $T$, the number of test cases.<\/p>\r\n\r\n<p>Each test case will be given in two lines. The first line will contain $n$ and $k$, separated by whitespace. The second line will describe $A$, without whitespace, as a string of length $n$.<\/p>\r\n","output":"<p>Output each test case&#39;s answer in each line.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>$1 &le; T &le; 10$<\/li>\r\n\t<li>$1 &le; k &le; n &le; 1\\,000\\,000$<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>Case 1: There is only one way to cut the cake of length $1$ (where you would cut it $0$ times).<\/p>\r\n\r\n<p>Case 2: Similar to Case 1, the answer is $1$ when $k = 1$.<\/p>\r\n\r\n<p>Case 3: There are two ways to cut the cake: <code>[01][010]<\/code> and <code>[010][10]<\/code>.<\/p>\r\n\r\n<p>Case 4: There are two units with toppings, but since $k = 3$, there is no way to satisfy condition 2.<\/p>\r\n\r\n<p>Case 5: Discussed in the problem statement.<\/p>\r\n\r\n<p>Case 8: The answer is $3\\,486\\,784\\,401$, but you must output the answer modulo $10^9+7$.<\/p>\r\n\r\n<p>Case 9: Note that the cake may not have any toppings. <\/p>\r\n"}]

시간 제한

  • Java 8: 3 초
  • Python 3: 5 초
  • PyPy3: 5 초
  • Java 8 (OpenJDK): 3 초
  • Java 11: 3 초
  • Kotlin (JVM): 3 초
  • Java 15: 3 초