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

문제

Albert는 Alice의 가게에서 포장하여 우편으로 부치는 일을 도와주기로 했다. 물건을 포장하는 일은 번거롭지만 간단하다.

우선 길이가 B로 동일한 상자를 여러 개 준비한다 (몇 개 준비해야 충분한지 계산하는 것이 Albert의 일이다). 하루 동안 총 R대의 트럭이 공장에서 가게로 물건을 배달해오는데, 한 번에 한 대의 트럭에서 물건을 모두 배달 받은 후 다음 트럭에서 물건을 배달 받는 식으로 진행한다. 각 트럭은 모두 똑같이 n개의 물건을 배달하며, 각 물건에 1번부터 n번까지 고유한 번호가 붙어 있어서 이 순서대로 물건을 꺼내야만 한다.
i번째 물건의 길이를 v[i]라 하자.

아래 그림은 R = 4, n = 3 이고 v = [2, 2, 3]인 경우를 보여준다. 즉 각각의 트럭에 길이가 2, 2, 3인 물건이 실려있고, 이 순서로 (좌에서 우로) 물건을 꺼낸다고 생각하면 된다.

Albert는 이 물건들을 길이가 B인 상자에 순서대로 넣어서 잘 포장하여 목적지에 부치는 일을 도와주기로 했다. 단, 앞서 언급한대로 1번 트럭부터 R번 트럭까지, 그리고 각 트럭에서 물건을 번호 순서대로 꺼내서 넣어야만 한다.

예를 들어 B = 5 인 경우, 위 예제의 경우 상자가 총 여섯 개 필요하다. 아래 그림은 좌측부터 순서대로 여섯 개의 상자를 이용하여 Albert가 물건을 채운 모습을 나타낸다.

  • 먼저, 1번 트럭에서 1번과 2번 물건을 꺼내 첫 번째 상자에 담는다. 3번 물건을 넣기에는 상자의 길이가 모자라므로 두 번째 상자가 필요하다.
  • 두 번째 상자에는 1번 트럭에서 꺼낸 3번 물건과 2번 트럭에서 꺼낸 1번 물건을 넣을 수 있다.
  • 세 번째 상자에는 2번 트럭에서 꺼낸 2번과 3번 물건을 넣을 수 있다.
  • 네 번째 상자에는 3번 트럭에서 1번과 2번 물건을 넣을 수 있다.
  • 다섯 번째 상자에는 3번 트럭에서 꺼낸 3번 물건과 4번 트럭에서 꺼낸 1번 물건을 넣을 수 있다.
  • 마지막 여섯 번째 상자에는 4번 트럭에서 2번과 3번 물건을 넣을 수 있다.
  • 따라서 이 경우 총 여섯 개의 상자가 필요하다.

Albert는 트럭이 배달을 시작하기 전 미리 상자가 몇 개나 필요할지 계산해서 Alice에게 알려주어야 한다.

입력으로 n, B, R, 그리고 물건의 길이를 나타내는 v 값들이 주어졌을 때, 길이가 B인 상자가 총 몇 개 필요한지 계산해보자.

입력

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

각 테스트 케이스는 두 줄에 걸쳐 주어진다.

테스트 케이스의 첫 줄에 n, B, R이 주어진다. 둘째 줄에 물건의 길이를 나타내는 n개의 정수가 공백으로 구분되어 주어진다. 

출력

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

제한

  • 1 ≤ T ≤ 10
  • 1 ≤ n, B ≤ 4,000
  • (각 물건 i에 대하여) 1 ​​≤ v[i] ≤ B
  • 1 ≤ R ≤ 1015

예제 입력 1

5
4 6 3
1 1 1 1
3 5 4
2 2 3
5 5 4
2 2 3 3 2
7 5 5
2 3 2 2 3 2 3
2 4000 12345678912345
1234 2345

예제 출력 1

2
6
12
18
12345678912345

예제 1: 총 12개의 물건이 있고, 각 물건의 길이가 1이다. 각 상자의 길이는 6이므로 상자 두 개가 필요하다.

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

예제 3-4: 추가 설명 없음.

예제 5: R값의 범위에 주의하자.

[{"problem_id":"23026","problem_lang":"0","title":"\ubb3c\uac74 \ud3ec\uc7a5\ud558\uae30","description":"<p>Albert\ub294 Alice\uc758 \uac00\uac8c\uc5d0\uc11c&nbsp;\ud3ec\uc7a5\ud558\uc5ec \uc6b0\ud3b8\uc73c\ub85c \ubd80\uce58\ub294 \uc77c\uc744 \ub3c4\uc640\uc8fc\uae30\ub85c \ud588\ub2e4. \ubb3c\uac74\uc744 \ud3ec\uc7a5\ud558\ub294 \uc77c\uc740 \ubc88\uac70\ub86d\uc9c0\ub9cc \uac04\ub2e8\ud558\ub2e4.<\/p>\r\n\r\n<p>\uc6b0\uc120 \uae38\uc774\uac00 B\ub85c \ub3d9\uc77c\ud55c \uc0c1\uc790\ub97c \uc5ec\ub7ec \uac1c \uc900\ube44\ud55c\ub2e4 (\uba87 \uac1c \uc900\ube44\ud574\uc57c \ucda9\ubd84\ud55c\uc9c0 \uacc4\uc0b0\ud558\ub294 \uac83\uc774 Albert\uc758 \uc77c\uc774\ub2e4). \ud558\ub8e8 \ub3d9\uc548 \ucd1d R\ub300\uc758 \ud2b8\ub7ed\uc774 \uacf5\uc7a5\uc5d0\uc11c \uac00\uac8c\ub85c \ubb3c\uac74\uc744 \ubc30\ub2ec\ud574\uc624\ub294\ub370, \ud55c \ubc88\uc5d0 \ud55c \ub300\uc758 \ud2b8\ub7ed\uc5d0\uc11c \ubb3c\uac74\uc744 \ubaa8\ub450 \ubc30\ub2ec \ubc1b\uc740 \ud6c4 \ub2e4\uc74c \ud2b8\ub7ed\uc5d0\uc11c \ubb3c\uac74\uc744 \ubc30\ub2ec \ubc1b\ub294 \uc2dd\uc73c\ub85c \uc9c4\ud589\ud55c\ub2e4. \uac01 \ud2b8\ub7ed\uc740 \ubaa8\ub450 \ub611\uac19\uc774 n\uac1c\uc758 \ubb3c\uac74\uc744 \ubc30\ub2ec\ud558\uba70, \uac01 \ubb3c\uac74\uc5d0 1\ubc88\ubd80\ud130 n\ubc88\uae4c\uc9c0 \uace0\uc720\ud55c \ubc88\ud638\uac00 \ubd99\uc5b4 \uc788\uc5b4\uc11c \uc774 \uc21c\uc11c\ub300\ub85c \ubb3c\uac74\uc744 \uaebc\ub0b4\uc57c\ub9cc \ud55c\ub2e4.<br \/>\r\ni\ubc88\uc9f8 \ubb3c\uac74\uc758 \uae38\uc774\ub97c v[i]\ub77c \ud558\uc790.<\/p>\r\n\r\n<p>\uc544\ub798 \uadf8\ub9bc\uc740 R = 4, n = 3&nbsp;\uc774\uace0 v = [2, 2, 3]\uc778 \uacbd\uc6b0\ub97c \ubcf4\uc5ec\uc900\ub2e4. \uc989 \uac01\uac01\uc758 \ud2b8\ub7ed\uc5d0 \uae38\uc774\uac00 2, 2, 3\uc778 \ubb3c\uac74\uc774 \uc2e4\ub824\uc788\uace0, \uc774 \uc21c\uc11c\ub85c (\uc88c\uc5d0\uc11c \uc6b0\ub85c) \ubb3c\uac74\uc744 \uaebc\ub0b8\ub2e4\uace0 \uc0dd\uac01\ud558\uba74 \ub41c\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/ba309e77-c866-4fb3-969e-76334f492349\/-\/preview\/\" style=\"height: 39px; width: 600px;\" \/><\/p>\r\n\r\n<p>Albert\ub294 \uc774 \ubb3c\uac74\ub4e4\uc744 \uae38\uc774\uac00 B\uc778 \uc0c1\uc790\uc5d0 \uc21c\uc11c\ub300\ub85c \ub123\uc5b4\uc11c \uc798 \ud3ec\uc7a5\ud558\uc5ec \ubaa9\uc801\uc9c0\uc5d0 \ubd80\uce58\ub294 \uc77c\uc744 \ub3c4\uc640\uc8fc\uae30\ub85c \ud588\ub2e4. \ub2e8, \uc55e\uc11c \uc5b8\uae09\ud55c\ub300\ub85c 1\ubc88 \ud2b8\ub7ed\ubd80\ud130 R\ubc88 \ud2b8\ub7ed\uae4c\uc9c0, \uadf8\ub9ac\uace0 \uac01 \ud2b8\ub7ed\uc5d0\uc11c \ubb3c\uac74\uc744 \ubc88\ud638 \uc21c\uc11c\ub300\ub85c \uaebc\ub0b4\uc11c \ub123\uc5b4\uc57c\ub9cc \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4 B = 5 \uc778 \uacbd\uc6b0, \uc704 \uc608\uc81c\uc758 \uacbd\uc6b0 \uc0c1\uc790\uac00 \ucd1d \uc5ec\uc12f \uac1c \ud544\uc694\ud558\ub2e4. \uc544\ub798 \uadf8\ub9bc\uc740&nbsp;\uc88c\uce21\ubd80\ud130 \uc21c\uc11c\ub300\ub85c \uc5ec\uc12f \uac1c\uc758 \uc0c1\uc790\ub97c \uc774\uc6a9\ud558\uc5ec&nbsp;Albert\uac00 \ubb3c\uac74\uc744 \ucc44\uc6b4 \ubaa8\uc2b5\uc744 \ub098\ud0c0\ub0b8\ub2e4.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/f225b9ff-4cdb-4656-b233-01f419ea71ea\/-\/preview\/\" style=\"height: 35px; width: 600px;\" \/><\/p>\r\n\r\n<ul>\r\n\t<li>\uba3c\uc800, 1\ubc88 \ud2b8\ub7ed\uc5d0\uc11c 1\ubc88\uacfc 2\ubc88 \ubb3c\uac74\uc744 \uaebc\ub0b4 \uccab \ubc88\uc9f8 \uc0c1\uc790\uc5d0 \ub2f4\ub294\ub2e4. 3\ubc88 \ubb3c\uac74\uc744 \ub123\uae30\uc5d0\ub294 \uc0c1\uc790\uc758 \uae38\uc774\uac00 \ubaa8\uc790\ub77c\ubbc0\ub85c \ub450 \ubc88\uc9f8 \uc0c1\uc790\uac00 \ud544\uc694\ud558\ub2e4.<\/li>\r\n\t<li>\ub450 \ubc88\uc9f8 \uc0c1\uc790\uc5d0\ub294 1\ubc88 \ud2b8\ub7ed\uc5d0\uc11c \uaebc\ub0b8 3\ubc88 \ubb3c\uac74\uacfc 2\ubc88 \ud2b8\ub7ed\uc5d0\uc11c \uaebc\ub0b8 1\ubc88 \ubb3c\uac74\uc744 \ub123\uc744 \uc218 \uc788\ub2e4.<\/li>\r\n\t<li>\uc138 \ubc88\uc9f8 \uc0c1\uc790\uc5d0\ub294 2\ubc88 \ud2b8\ub7ed\uc5d0\uc11c \uaebc\ub0b8 2\ubc88\uacfc 3\ubc88 \ubb3c\uac74\uc744 \ub123\uc744 \uc218 \uc788\ub2e4.<\/li>\r\n\t<li>\ub124 \ubc88\uc9f8 \uc0c1\uc790\uc5d0\ub294 3\ubc88 \ud2b8\ub7ed\uc5d0\uc11c 1\ubc88\uacfc 2\ubc88 \ubb3c\uac74\uc744 \ub123\uc744 \uc218 \uc788\ub2e4.<\/li>\r\n\t<li>\ub2e4\uc12f \ubc88\uc9f8 \uc0c1\uc790\uc5d0\ub294 3\ubc88 \ud2b8\ub7ed\uc5d0\uc11c \uaebc\ub0b8 3\ubc88 \ubb3c\uac74\uacfc 4\ubc88 \ud2b8\ub7ed\uc5d0\uc11c \uaebc\ub0b8 1\ubc88 \ubb3c\uac74\uc744 \ub123\uc744 \uc218 \uc788\ub2e4.<\/li>\r\n\t<li>\ub9c8\uc9c0\ub9c9 \uc5ec\uc12f \ubc88\uc9f8 \uc0c1\uc790\uc5d0\ub294 4\ubc88 \ud2b8\ub7ed\uc5d0\uc11c 2\ubc88\uacfc 3\ubc88 \ubb3c\uac74\uc744 \ub123\uc744 \uc218 \uc788\ub2e4.<\/li>\r\n\t<li>\ub530\ub77c\uc11c \uc774 \uacbd\uc6b0 \ucd1d \uc5ec\uc12f \uac1c\uc758 \uc0c1\uc790\uac00 \ud544\uc694\ud558\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>Albert\ub294 \ud2b8\ub7ed\uc774 \ubc30\ub2ec\uc744 \uc2dc\uc791\ud558\uae30 \uc804 \ubbf8\ub9ac \uc0c1\uc790\uac00 \uba87 \uac1c\ub098 \ud544\uc694\ud560\uc9c0 \uacc4\uc0b0\ud574\uc11c Alice\uc5d0\uac8c \uc54c\ub824\uc8fc\uc5b4\uc57c \ud55c\ub2e4.<\/p>\r\n\r\n<p>\uc785\ub825\uc73c\ub85c n, B, R, \uadf8\ub9ac\uace0 \ubb3c\uac74\uc758 \uae38\uc774\ub97c \ub098\ud0c0\ub0b4\ub294 v \uac12\ub4e4\uc774 \uc8fc\uc5b4\uc84c\uc744 \ub54c, \uae38\uc774\uac00 B\uc778 \uc0c1\uc790\uac00 \ucd1d \uba87 \uac1c \ud544\uc694\ud55c\uc9c0 \uacc4\uc0b0\ud574\ubcf4\uc790.<\/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 \uac78\uccd0 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\ud14c\uc2a4\ud2b8 \ucf00\uc774\uc2a4\uc758 \uccab \uc904\uc5d0 n, B, R\uc774 \uc8fc\uc5b4\uc9c4\ub2e4. \ub458\uc9f8 \uc904\uc5d0 \ubb3c\uac74\uc758 \uae38\uc774\ub97c \ub098\ud0c0\ub0b4\ub294 n\uac1c\uc758 \uc815\uc218\uac00 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc8fc\uc5b4\uc9c4\ub2e4.&nbsp;<\/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; n, B &le; 4,000<\/li>\r\n\t<li>(\uac01 \ubb3c\uac74 i\uc5d0 \ub300\ud558\uc5ec) 1 \u200b\u200b&le; v[i] &le; B<\/li>\r\n\t<li>1 &le; R &le; 10<sup>15<\/sup><\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>\uc608\uc81c 1: \ucd1d 12\uac1c\uc758 \ubb3c\uac74\uc774 \uc788\uace0, \uac01 \ubb3c\uac74\uc758 \uae38\uc774\uac00 1\uc774\ub2e4. \uac01 \uc0c1\uc790\uc758 \uae38\uc774\ub294 6\uc774\ubbc0\ub85c \uc0c1\uc790 \ub450 \uac1c\uac00 \ud544\uc694\ud558\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 2: \ubcf8\ubb38\uc5d0\uc11c \ub2e4\ub8e8\uc5c8\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 3-4: \ucd94\uac00 \uc124\uba85 \uc5c6\uc74c.<\/p>\r\n\r\n<p>\uc608\uc81c 5: R\uac12\uc758 \ubc94\uc704\uc5d0 \uc8fc\uc758\ud558\uc790.<\/p>\r\n"},{"problem_id":"23026","problem_lang":"1","title":"Shipping Boxes","description":"<p>Albert helps Alice ship boxes to customers. It&#39;s tedious but pretty simple.&nbsp;<\/p>\r\n\r\n<p>First, Albert needs to prepare many boxes of length B (his job is to figure out exactly how many boxes he would need). Each day, R trucks deliver items from factory to Alice&#39;s warehouse such that all items of a truck must be unloaded first before any item of the next truck can be unloaded. Each truck delivers the same&nbsp;n items (that are numbered from 1 to n), and the items must be unloaded in this order. Let v[i] be the length of item i.<\/p>\r\n\r\n<p>The image below describes an example where R = 4, n = 3, and v = [2, 2, 3]. That is, each truck contains three items of lengths 2, 2, and 3, and imagine that Albert would take items out exactly&nbsp;in this order (from left to right).<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/ba309e77-c866-4fb3-969e-76334f492349\/-\/preview\/\" style=\"height: 39px; width: 600px;\" \/><\/p>\r\n\r\n<p>Albert needs to put these items into boxes of length B before shipping them. As mentioned earlier, Albert must unload truck 1 to R, and put items in the same order as they are in each truck.<\/p>\r\n\r\n<p>When B = 5, Albert would need six boxes for the earlier example (above). The image below shows how Albert would use six boxes filled with the items.<\/p>\r\n\r\n<p style=\"text-align: center;\"><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/f225b9ff-4cdb-4656-b233-01f419ea71ea\/-\/preview\/\" style=\"height: 35px; width: 600px;\" \/><\/p>\r\n\r\n<ul>\r\n\t<li>First, Albert puts items 1 and 2 from truck 1 into the first box. Item 3 cannot fit, so he needs another box.<\/li>\r\n\t<li>In box 2, Albert can put item 3 from truck 1 and item 1 from truck 2.<\/li>\r\n\t<li>In box 3, Albert can put items 2 and 3 from truck 2.<\/li>\r\n\t<li>In box 4, Albert can put items 1 and 2 from truck 3.<\/li>\r\n\t<li>In box 5, Albert can put item 3 from truck 3 and item 1 from truck 4.<\/li>\r\n\t<li>In box 6, Albert can put items 2 and 3 from truck 4.<\/li>\r\n\t<li>Hence, Albert would need six boxes in this example.&nbsp;<\/li>\r\n<\/ul>\r\n\r\n<p>Albert needs to let Alice know how many boxes they would need before trucks begin delivering the items.&nbsp;<\/p>\r\n\r\n<p>Given n, B, R, and v, help Albert calculate the number of boxes he needs.<\/p>\r\n","input":"<p>The first line of the input will contain an integer T, the number of test cases.<\/p>\r\n\r\n<p>Each test case will consist of two lines. The first line will contain n, B, and R, separated by whitespace. The second line will contain v[1], ... v,[n], separated by whitespace.&nbsp;<\/p>\r\n","output":"<p>For each test case, output the 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; n, B &le; 4,000<\/li>\r\n\t<li>For each item i, 1 \u200b\u200b&le; v[i] &le; B<\/li>\r\n\t<li>1 &le; R &le; 10<sup>15<\/sup><\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>Case 1: There are 12 items each of which has length 1. Each box&#39;s length is 6, so they will need two boxes.<\/p>\r\n\r\n<p>Case 2: Discussed in the problem statement.<\/p>\r\n\r\n<p>Case 3-4: No explanation provided.<\/p>\r\n\r\n<p>Case 5: Pay attention to the range of R.<\/p>\r\n"}]

시간 제한

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