시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 (추가 시간 없음) 512 MB40211976.000%

문제

길이가 n인 문자열 S를 아래 조건에 따라 k개의 부분문자열 (substring) T1, T2, ..., Tk로 쪼개는 경우를 생각해보자:

  • 1 ≤ k ≤ n
  • 1 ≤ i ≤ k를 만족하는 i에 대하여 각 부분문자열 Ti는 길이 1 이상이며 S의 부분문자열이다 (즉, S를 구성하는 연속한 문자들로 구성되어있다).
  • T1, T2, ..., Tk 를 순서대로 이어붙이면 (string concatenation) 원래의 문자열 S가 된다.

예를 들어 S = "FED" 인 경우 아래와 같은 총 4가지의 방법으로 쪼갤 수 있다:

  • 방법 1: T1 = "FED" (이 경우, k = 1)
  • 방법 2: T1 = "F", T2 = "ED" (이 경우, k = 2)
  • 방법 3: T1 = "FE", T2 = "D" (이 경우, k = 2)
  • 방법 4: T1 = "F", T2 = "E", T3 = "D" (이 경우, k = 3)

참고로 길이가 n인 문자열을 위 조건대로 쪼개는 방법은 총 2n-1 가지 존재한다.

이 문제에서는 원래의 문자열 S가 0-9와 A-F로만 구성된 16진수라 가정한다.

Albert는 위 조건대로 S를 쪼개서 T1, T2, ..., Tk가 비감소수열이 (non-decreasing sequence) 되는 경우가 몇 가지나 되는지 알고 싶다.
구체적으로, Albert는 S를 쪼갠 후 각 부분 문자열이 타나내는 16진수 값이 T1 ≤ T2 ≤ ... ≤ Tk 를 만족하도록 하고 싶다.

위 예제의 경우, 상기한 네 가지 방법을 통해 만들어지는 수열은 아래와 같다:

  • 방법1: [FED(16) = 4077] (비감소수열)
  • 방법2: [F(16) = 15, ED(16) = 237] (비감소수열)
  • 방법3: [FE(16) = 254, D(16) = 13]
  • 방법4: [F(16) = 15, E(16) = 14, D(16) = 13]

이 경우 비감소수열은 방법1, 방법2을 통해 얻을 수 있으므로 답이 2가 된다.

다른 예로 S = "0070"인 경우, 아래와 같은 4가지 방법이 가능하다.

  • 방법 1: T1 = "0070"
  • 방법 2: T1 = "0", T2 = "0", T3 = "70" (이 경우 [0, 0, 70(16) = 112] 이다)
  • 방법 3: T1 = "00", T2 = "70"
  • 방법 4: T1 = "0", T2 = "070"

방법1, 방법3, 방법4에서 보이듯 부분 문자열이 선행 0을 (leading zero) 포함하는 것도 허용된다.

입력으로 16진수 문자열 S가 주어졌을 때, Albert가 몇 가지 방법으로 S를 부분 문자열로 쪼개서 비감소수열을 얻을 수 있는지 구해보자.

입력

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

다음 각 줄에 문자열 S가 주어진다.

문자열 S를 구성하는 문자는 16진법에 사용되는 0-9 (숫자)와 A-F (영대문자) 뿐이다.

출력

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

제한

  • 1 ≤ T ≤ 20
  • 1 ≤ n ≤ 15
  • S를 구성하는 문자는 0-9 와 A-F 뿐이다

예제 입력 1

4
0070
FED
42
002021

예제 출력 1

4
2
1
12

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

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

예제 3: [42]가 유일한 방법이다.

예제 4: 추가 설명 없음.

 

[{"problem_id":"21979","problem_lang":"0","title":"16\uc9c4\uc218 \ucabc\uac1c\uae30","description":"<p>\uae38\uc774\uac00 n\uc778 \ubb38\uc790\uc5f4 S\ub97c \uc544\ub798 \uc870\uac74\uc5d0 \ub530\ub77c&nbsp;k\uac1c\uc758 \ubd80\ubd84\ubb38\uc790\uc5f4 (substring) T<sub>1<\/sub>, T<sub>2<\/sub>, ..., T<sub>k<\/sub>\ub85c \ucabc\uac1c\ub294 \uacbd\uc6b0\ub97c \uc0dd\uac01\ud574\ubcf4\uc790:<\/p>\r\n\r\n<ul>\r\n\t<li>1 &le; k &le; n<\/li>\r\n\t<li>1 &le; i &le; k\ub97c \ub9cc\uc871\ud558\ub294 i\uc5d0 \ub300\ud558\uc5ec \uac01 \ubd80\ubd84\ubb38\uc790\uc5f4 T<sub>i<\/sub>\ub294 \uae38\uc774 1 \uc774\uc0c1\uc774\uba70 S\uc758 \ubd80\ubd84\ubb38\uc790\uc5f4\uc774\ub2e4 (\uc989, S\ub97c \uad6c\uc131\ud558\ub294 \uc5f0\uc18d\ud55c \ubb38\uc790\ub4e4\ub85c \uad6c\uc131\ub418\uc5b4\uc788\ub2e4).<\/li>\r\n\t<li>T<sub>1<\/sub>, T<sub>2<\/sub>, ..., T<sub>k<\/sub> \ub97c \uc21c\uc11c\ub300\ub85c \uc774\uc5b4\ubd99\uc774\uba74 (string&nbsp;concatenation) \uc6d0\ub798\uc758 \ubb38\uc790\uc5f4 S\uac00 \ub41c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4 S = &quot;FED&quot; \uc778 \uacbd\uc6b0 \uc544\ub798\uc640 \uac19\uc740 \ucd1d 4\uac00\uc9c0\uc758 \ubc29\ubc95\uc73c\ub85c \ucabc\uac24 \uc218 \uc788\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/7066b041-642b-4482-a97d-dc7e5b1e5fb4\/-\/preview\/\" style=\"width: 120px; height: 145px; float: right;\" \/>\ubc29\ubc95 1: T1 = &quot;FED&quot; (\uc774 \uacbd\uc6b0, k = 1)<\/li>\r\n\t<li>\ubc29\ubc95 2: T1 = &quot;F&quot;, T2 = &quot;ED&quot; (\uc774 \uacbd\uc6b0, k = 2)<\/li>\r\n\t<li>\ubc29\ubc95 3: T1 = &quot;FE&quot;, T2 = &quot;D&quot; (\uc774 \uacbd\uc6b0, k = 2)<\/li>\r\n\t<li>\ubc29\ubc95 4: T1 = &quot;F&quot;, T2 = &quot;E&quot;, T3 = &quot;D&quot; (\uc774 \uacbd\uc6b0, k = 3)<\/li>\r\n<\/ul>\r\n\r\n<p>\ucc38\uace0\ub85c&nbsp;\uae38\uc774\uac00 n\uc778 \ubb38\uc790\uc5f4\uc744 \uc704 \uc870\uac74\ub300\ub85c \ucabc\uac1c\ub294 \ubc29\ubc95\uc740 \ucd1d 2<sup>n-1<\/sup> \uac00\uc9c0 \uc874\uc7ac\ud55c\ub2e4.<\/p>\r\n\r\n<p>\uc774 \ubb38\uc81c\uc5d0\uc11c\ub294 \uc6d0\ub798\uc758 \ubb38\uc790\uc5f4 S\uac00 0-9\uc640 A-F\ub85c\ub9cc \uad6c\uc131\ub41c 16\uc9c4\uc218\ub77c \uac00\uc815\ud55c\ub2e4.<\/p>\r\n\r\n<p>Albert\ub294 \uc704 \uc870\uac74\ub300\ub85c S\ub97c&nbsp;\ucabc\uac1c\uc11c T<sub>1<\/sub>, T<sub>2<\/sub>, ..., T<sub>k<\/sub>\uac00 \ube44\uac10\uc18c\uc218\uc5f4\uc774 (non-decreasing sequence)&nbsp;\ub418\ub294 \uacbd\uc6b0\uac00 \uba87 \uac00\uc9c0\ub098 \ub418\ub294\uc9c0 \uc54c\uace0 \uc2f6\ub2e4.<br \/>\r\n\uad6c\uccb4\uc801\uc73c\ub85c, Albert\ub294 S\ub97c \ucabc\uac20 \ud6c4&nbsp;\uac01 \ubd80\ubd84 \ubb38\uc790\uc5f4\uc774 \ud0c0\ub098\ub0b4\ub294 16\uc9c4\uc218 \uac12\uc774 T<sub>1<\/sub> &le; T<sub>2<\/sub> &le; ... &le; T<sub>k<\/sub> \ub97c \ub9cc\uc871\ud558\ub3c4\ub85d \ud558\uace0 \uc2f6\ub2e4.<\/p>\r\n\r\n<p>\uc704 \uc608\uc81c\uc758 \uacbd\uc6b0, \uc0c1\uae30\ud55c \ub124 \uac00\uc9c0 \ubc29\ubc95\uc744 \ud1b5\ud574 \ub9cc\ub4e4\uc5b4\uc9c0\ub294 \uc218\uc5f4\uc740 \uc544\ub798\uc640 \uac19\ub2e4:<\/p>\r\n\r\n<ul>\r\n\t<li>\ubc29\ubc951: [FED<sub>(16)<\/sub> = 4077] (\ube44\uac10\uc18c\uc218\uc5f4)<\/li>\r\n\t<li>\ubc29\ubc952: [F<sub>(16)<\/sub> = 15, ED<sub>(16)<\/sub> = 237] (\ube44\uac10\uc18c\uc218\uc5f4)<\/li>\r\n\t<li>\ubc29\ubc953: [FE<sub>(16)<\/sub> = 254, D<sub>(16)<\/sub> = 13]<\/li>\r\n\t<li>\ubc29\ubc954: [F<sub>(16)<\/sub> = 15, E<sub>(16)<\/sub> = 14, D<sub>(16)<\/sub> = 13]<\/li>\r\n<\/ul>\r\n\r\n<p>\uc774 \uacbd\uc6b0 \ube44\uac10\uc18c\uc218\uc5f4\uc740 \ubc29\ubc951, \ubc29\ubc952\uc744 \ud1b5\ud574 \uc5bb\uc744 \uc218 \uc788\uc73c\ubbc0\ub85c \ub2f5\uc774 2\uac00 \ub41c\ub2e4.<\/p>\r\n\r\n<p>\ub2e4\ub978 \uc608\ub85c S = &quot;0070&quot;\uc778 \uacbd\uc6b0, \uc544\ub798\uc640 \uac19\uc740 4\uac00\uc9c0 \ubc29\ubc95\uc774 \uac00\ub2a5\ud558\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>\ubc29\ubc95 1: T1 = &quot;0070&quot;<\/li>\r\n\t<li>\ubc29\ubc95 2: T1 = &quot;0&quot;, T2 = &quot;0&quot;, T3 = &quot;70&quot; (\uc774 \uacbd\uc6b0 [0, 0, 70<sub>(16)<\/sub> = 112] \uc774\ub2e4)<\/li>\r\n\t<li>\ubc29\ubc95 3: T1 = &quot;00&quot;, T2 = &quot;70&quot;<\/li>\r\n\t<li>\ubc29\ubc95 4: T1 = &quot;0&quot;, T2 = &quot;070&quot;<\/li>\r\n<\/ul>\r\n\r\n<p>\ubc29\ubc951, \ubc29\ubc953,&nbsp;\ubc29\ubc954\uc5d0\uc11c \ubcf4\uc774\ub4ef \ubd80\ubd84 \ubb38\uc790\uc5f4\uc774 \uc120\ud589 0\uc744&nbsp;(leading zero) \ud3ec\ud568\ud558\ub294 \uac83\ub3c4 \ud5c8\uc6a9\ub41c\ub2e4.<\/p>\r\n\r\n<p>\uc785\ub825\uc73c\ub85c 16\uc9c4\uc218 \ubb38\uc790\uc5f4 S\uac00 \uc8fc\uc5b4\uc84c\uc744 \ub54c, Albert\uac00 \uba87 \uac00\uc9c0 \ubc29\ubc95\uc73c\ub85c S\ub97c \ubd80\ubd84 \ubb38\uc790\uc5f4\ub85c \ucabc\uac1c\uc11c \ube44\uac10\uc18c\uc218\uc5f4\uc744 \uc5bb\uc744 \uc218 \uc788\ub294\uc9c0 \uad6c\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.&nbsp;<\/p>\r\n\r\n<p>\ub2e4\uc74c \uac01 \uc904\uc5d0 \ubb38\uc790\uc5f4 S\uac00 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\ubb38\uc790\uc5f4 S\ub97c \uad6c\uc131\ud558\ub294 \ubb38\uc790\ub294 16\uc9c4\ubc95\uc5d0 \uc0ac\uc6a9\ub418\ub294&nbsp;0-9 (\uc22b\uc790)\uc640 A-F (\uc601\ub300\ubb38\uc790) \ubfd0\uc774\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; 20<\/li>\r\n\t<li>1 &le; n&nbsp;&le; 15<\/li>\r\n\t<li>S\ub97c \uad6c\uc131\ud558\ub294 \ubb38\uc790\ub294 0-9 \uc640 A-F \ubfd0\uc774\ub2e4<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>\uc608\uc81c 1: \ubcf8\ubb38\uc5d0\uc11c \ub2e4\ub8e8\uc5c8\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:&nbsp;[42]\uac00 \uc720\uc77c\ud55c \ubc29\ubc95\uc774\ub2e4.<\/p>\r\n\r\n<p>\uc608\uc81c 4: \ucd94\uac00 \uc124\uba85 \uc5c6\uc74c.<\/p>\r\n\r\n<p>&nbsp;<\/p>\r\n"},{"problem_id":"21979","problem_lang":"1","title":"Splitting Hex Strings","description":"<p>Consider splitting a string S of length n into k substrings, T<sub>1<\/sub>, T<sub>2<\/sub>, ..., T<sub>k<\/sub>, according to the rules below:<\/p>\r\n\r\n<ul>\r\n\t<li>1 &le; k &le; n<\/li>\r\n\t<li>For each i with 1 &le; i &le; k,&nbsp;T<sub>i<\/sub> must be a substring of S with length at least 1&nbsp;(that is, T<sub>i<\/sub> must consist of consecutive character(s)&nbsp;in S).<\/li>\r\n\t<li>If you concatenate T<sub>1<\/sub>, T<sub>2<\/sub>, ..., T<sub>k<\/sub> in this order, it results in the original string S.<\/li>\r\n<\/ul>\r\n\r\n<p>For instance, if S = &quot;FED&quot;, then we can split it into four different ways as follows:<\/p>\r\n\r\n<ul>\r\n\t<li><img alt=\"\" src=\"https:\/\/upload.acmicpc.net\/7066b041-642b-4482-a97d-dc7e5b1e5fb4\/-\/preview\/\" style=\"height: 145px; width: 120px; float: right;\" \/>Option 1: T1 = &quot;FED&quot; (in this case, k = 1)<\/li>\r\n\t<li>Option 2: T1 = &quot;F&quot;, T2 = &quot;ED&quot; (in this case, k = 2)<\/li>\r\n\t<li>Option 3: T1 = &quot;FE&quot;, T2 = &quot;D&quot; (in this case, k = 2)<\/li>\r\n\t<li>Option 4: T1 = &quot;F&quot;, T2 = &quot;E&quot;, T3 = &quot;D&quot; (in this case, k = 3)<\/li>\r\n<\/ul>\r\n\r\n<p>For your information, there are&nbsp;2<sup>n-1<\/sup>&nbsp;ways to split a string of length n according to the rules above.<\/p>\r\n\r\n<p>In this problem, we assume that S is a hexadecimal string that only consists of &#39;0&#39;-&#39;9&#39; and &#39;A&#39;-&#39;F&#39;.<\/p>\r\n\r\n<p>Albert wants to know in how many ways he can split S into&nbsp;T<sub>1<\/sub>, T<sub>2<\/sub>, ..., T<sub>k<\/sub>&nbsp;such that the substrings form a non-decreasing sequence.<br \/>\r\nFormally, Albert wants to ensure that&nbsp;T<sub>1<\/sub> &le; T<sub>2<\/sub> &le; ... &le; T<sub>k<\/sub>&nbsp;is satisfied if each substring is interpreted as a hexadecimal number.<\/p>\r\n\r\n<p>In the example above, those four options lead to the following sequences:<\/p>\r\n\r\n<ul>\r\n\t<li>Option 1: [FED<sub>(16)<\/sub> = 4077] (a non-decreasing sequence)<\/li>\r\n\t<li>Option&nbsp;2: [F<sub>(16)<\/sub> = 15, ED<sub>(16)<\/sub> = 237] (a non-decreasing sequence)<\/li>\r\n\t<li>Option 3: [FE<sub>(16)<\/sub> = 254, D<sub>(16)<\/sub> = 13]<\/li>\r\n\t<li>Option 4: [F<sub>(16)<\/sub> = 15, E<sub>(16)<\/sub> = 14, D<sub>(16)<\/sub> = 13]<\/li>\r\n<\/ul>\r\n\r\n<p>In this case, the first two options lead to non-decreasing sequences, so the answer will be 2.<\/p>\r\n\r\n<p>In another example where S = &quot;0070&quot;, there are four ways to obtain non-decreasing sequences.<\/p>\r\n\r\n<ul>\r\n\t<li>Option 1: T1 = &quot;0070&quot;<\/li>\r\n\t<li>Option 2: T1 = &quot;0&quot;, T2 = &quot;0&quot;, T3 = &quot;70&quot; (in this case, the sequence is [0, 0, 70<sub>(16)<\/sub> = 112])<\/li>\r\n\t<li>Option 3: T1 = &quot;00&quot;, T2 = &quot;70&quot;<\/li>\r\n\t<li>Option 4: T1 = &quot;0&quot;, T2 = &quot;070&quot;<\/li>\r\n<\/ul>\r\n\r\n<p>As you can see in option 1, option 3, and option 4, substrings are allowed to contain leading zero(s).&nbsp;<\/p>\r\n\r\n<p>Given a hexadecimal string S, compute the number of ways in which Albert can split S into substrings such that the resulting sequence is a non-decreasing sequence.<\/p>\r\n","input":"<p>The first line of the input will contain a single number, T, the number of test cases.<\/p>\r\n\r\n<p>In each of the following T lines, an input string S will be given.<\/p>\r\n\r\n<p>S will only consist of&nbsp;0-9 (digits) and&nbsp;A-F (uppercase) that are used in hexadecimal numbers.<\/p>\r\n","output":"<p>For each test case, output the answer in a single line.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","limit":"<ul>\r\n\t<li>1 &le; T &le; 20<\/li>\r\n\t<li>1 &le; n&nbsp;&le; 15<\/li>\r\n\t<li>S will consist only of 0-9 and A-F.<\/li>\r\n<\/ul>\r\n","sample_explain_1":"<p>Case 1: Discussed in the problem statement.<\/p>\r\n\r\n<p>Case 2: Discussed in the problem statement.<\/p>\r\n\r\n<p>Case 3:&nbsp;[42] is the only way.<\/p>\r\n\r\n<p>Case 4: No explanation provided.<\/p>\r\n"}]