문제
DGIST 나라에는 문자열을 이용한 로또가 있다.
로또의 규칙은 아래와 같다.
- 구매
- 로또를 구매할 때 알파벳 대문자만으로 구성된 길이 $L$의 문자열을 $N$개 작성한다.
- 추첨
- 알파벳 대문자로만 구성된 길이 $K$의 문자열 $s$를 추첨한다.
- 구매 시 작성한 문자열의 모든 부분 문자열 중 $s$와 같은 것의 개수를 점수로 얻는다. 총점수는 구매 시 작성한 모든 문자열에 대한 점수의 총합이다.
- 여기서 부분 문자열이란, 문자열의 연속된 일부를 말한다.
aek, joo, ekj는 baekjoon의 부분 문자열이고, bak, p, oone는 부분 문자열이 아니다.
달구는 이번 주에 이 로또를 하나 구매했다. 달구가 이번 주 로또 추첨에서 얻을 수 있는 총 점수의 최댓값을 구하시오.
출력
첫 번째 줄에 달구가 이번 주 로또 추첨에서 얻을 수 있는 총 점수의 최댓값을 출력한다.
문자열 AB가 추첨된다면, ABABAB에서 3ドル$점,AABBAA에서 1ドル$점, AABBBB에서 1ドル$점, ABBAAB에서 2ドル$점을 얻어 총 7ドル$점을 얻을 수 있다. 이는 가능한 최대이다.
문자열 ZZ가 추첨된다면, ZZZZ에서 ZZZZ, ZZZZ, ZZZZ로 총 3점을 얻는다.
[{"problem_id":"34803","problem_lang":"0","title":"\ubb38\uc790\uc5f4 \ub85c\ub610","description":"<p>DGIST \ub098\ub77c\uc5d0\ub294 \ubb38\uc790\uc5f4\uc744 \uc774\uc6a9\ud55c \ub85c\ub610\uac00 \uc788\ub2e4.<\/p>\r\n\r\n<p>\ub85c\ub610\uc758 \uaddc\uce59\uc740 \uc544\ub798\uc640 \uac19\ub2e4.<\/p>\r\n\r\n<ul>\r\n<li>\uad6c\ub9e4\r\n\t<ul style=\"padding-left:20px;\">\r\n<li>\ub85c\ub610\ub97c \uad6c\ub9e4\ud560 \ub54c \uc54c\ud30c\ubcb3 \ub300\ubb38\uc790\ub9cc\uc73c\ub85c \uad6c\uc131\ub41c \uae38\uc774 $L$\uc758 \ubb38\uc790\uc5f4\uc744 $N$\uac1c \uc791\uc131\ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n<\/li>\r\n<li>\ucd94\ucca8\r\n\t<ul style=\"padding-left:20px;\">\r\n<li>\uc54c\ud30c\ubcb3 \ub300\ubb38\uc790\ub85c\ub9cc \uad6c\uc131\ub41c \uae38\uc774 $K$\uc758 \ubb38\uc790\uc5f4 $s$\ub97c \ucd94\ucca8\ud55c\ub2e4.<\/li>\r\n<li>\uad6c\ub9e4 \uc2dc \uc791\uc131\ud55c \ubb38\uc790\uc5f4\uc758 \ubaa8\ub4e0 \ubd80\ubd84 \ubb38\uc790\uc5f4 \uc911 $s$\uc640 \uac19\uc740 \uac83\uc758 \uac1c\uc218\ub97c \uc810\uc218\ub85c \uc5bb\ub294\ub2e4. \ucd1d\uc810\uc218\ub294 \uad6c\ub9e4 \uc2dc \uc791\uc131\ud55c \ubaa8\ub4e0 \ubb38\uc790\uc5f4\uc5d0 \ub300\ud55c \uc810\uc218\uc758 \ucd1d\ud569\uc774\ub2e4.<\/li>\r\n<li>\uc5ec\uae30\uc11c \ubd80\ubd84 \ubb38\uc790\uc5f4\uc774\ub780, \ubb38\uc790\uc5f4\uc758 \uc5f0\uc18d\ub41c \uc77c\ubd80\ub97c \ub9d0\ud55c\ub2e4. <code>aek<\/code>, <code>joo<\/code>, <code>ekj<\/code>\ub294 <code>baekjoon<\/code>\uc758 \ubd80\ubd84 \ubb38\uc790\uc5f4\uc774\uace0, <code>bak<\/code>, <code>p<\/code>, <code>oone<\/code>\ub294 \ubd80\ubd84 \ubb38\uc790\uc5f4\uc774 \uc544\ub2c8\ub2e4.<\/li>\r\n<\/ul>\r\n<\/li>\r\n<\/ul>\r\n\r\n<p>\ub2ec\uad6c\ub294 \uc774\ubc88 \uc8fc\uc5d0 \uc774 \ub85c\ub610\ub97c \ud558\ub098 \uad6c\ub9e4\ud588\ub2e4. \ub2ec\uad6c\uac00 \uc774\ubc88 \uc8fc \ub85c\ub610 \ucd94\ucca8\uc5d0\uc11c \uc5bb\uc744 \uc218 \uc788\ub294 \ucd1d \uc810\uc218\uc758 \ucd5c\ub313\uac12\uc744 \uad6c\ud558\uc2dc\uc624.<\/p>\r\n","input":"<p>\uccab \ubc88\uc9f8 \uc904\uc5d0, \ub85c\ub610\uc5d0 \ub4e4\uc5b4 \uc788\ub294 \ubb38\uc790\uc5f4\uc758 \uae38\uc774 $L$\uacfc \ubb38\uc790\uc5f4\uc758 \uac1c\uc218 $N$\uc774 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4 \uc815\uc218\ub85c \uc8fc\uc5b4\uc9c4\ub2e4. ($1 \\le L \\le 100$; $1 \\le N \\le 20$)<\/p>\r\n\r\n<p>\ub2e4\uc74c $N$\uac1c\uc758 \uc904\uc5d0 \uac78\uccd0, \ub2ec\uad6c\uac00 \uc774\ubc88 \uc8fc\uc5d0 \uad6c\ub9e4\ud55c \ub85c\ub610\uc5d0 \uc791\uc131\ud55c \ubb38\uc790\uc5f4\uc774 \ud55c \uc904\uc5d0 \ud558\ub098\uc529 \uc8fc\uc5b4\uc9c4\ub2e4. (\uc8fc\uc5b4\uc9c0\ub294 \ubb38\uc790\uc5f4\uc740 \uc54c\ud30c\ubcb3 \ub300\ubb38\uc790\ub85c\ub9cc \uc774\ub8e8\uc5b4\uc838\uc788\ub2e4.)<\/p>\r\n\r\n<p>$N+2$ \ubc88\uc9f8 \uc904\uc5d0 \uc815\uc218 $K$\uac00 \uc8fc\uc5b4\uc9c4\ub2e4. ($1 \\le K \\le L$)<\/p>\r\n","output":"<p>\uccab \ubc88\uc9f8 \uc904\uc5d0 \ub2ec\uad6c\uac00 \uc774\ubc88 \uc8fc \ub85c\ub610 \ucd94\ucca8\uc5d0\uc11c \uc5bb\uc744 \uc218 \uc788\ub294 \ucd1d \uc810\uc218\uc758 \ucd5c\ub313\uac12\uc744 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n","hint":"","original":"1","html_title":"0","problem_lang_tcode":"Korean","sample_explain_1":"<p>\ubb38\uc790\uc5f4 <code><span style=\"color:#e74c3c;\">AB<\/span><\/code>\uac00 \ucd94\ucca8\ub41c\ub2e4\uba74, <span style=\"color:#e74c3c;\"><code>ABABAB<\/code><\/span>\uc5d0\uc11c $3$\uc810,<code>A<span style=\"color:#e74c3c;\">AB<\/span>BAA<\/code>\uc5d0\uc11c $1$\uc810, <code>A<span style=\"color:#e74c3c;\">AB<\/span>BBB<\/code>\uc5d0\uc11c $1$\uc810, <code><span style=\"color:#e74c3c;\">AB<\/span>BA<span style=\"color:#e74c3c;\">AB<\/span><\/code>\uc5d0\uc11c $2$\uc810\uc744 \uc5bb\uc5b4 \ucd1d $7$\uc810\uc744 \uc5bb\uc744 \uc218 \uc788\ub2e4. \uc774\ub294 \uac00\ub2a5\ud55c \ucd5c\ub300\uc774\ub2e4.<\/p>\r\n","sample_explain_2":"<p>\ubb38\uc790\uc5f4 <span style=\"color:#e74c3c;\"><code>ZZ<\/code><\/span>\uac00 \ucd94\ucca8\ub41c\ub2e4\uba74, <span style=\"color:#e74c3c;\"><code>ZZZZ<\/code><\/span>\uc5d0\uc11c <code><span style=\"color:#e74c3c;\">ZZ<\/span>ZZ<\/code>, <code>Z<span style=\"color:#e74c3c;\">ZZ<\/span>Z<\/code>, <code>ZZ<span style=\"color:#e74c3c;\">ZZ<\/span><\/code>\ub85c \ucd1d 3\uc810\uc744 \uc5bb\ub294\ub2e4.<\/p>\r\n"},{"problem_id":"34803","problem_lang":"1","title":"String Lotto","description":"<p>In the country of DGIST, there is a special kind of lottery that uses strings.<\/p>\r\n\r\n<p>The rules of this lottery are as follows.<\/p>\r\n\r\n<ul>\r\n\t<li>Purchase\r\n\t<ul style=\"padding-left:20px;\">\r\n\t\t<li>When buying a lottery ticket, you write $N$&nbsp;strings, each consisting only of uppercase English letters and having a length of $L$.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n\t<li>Drawing\r\n\t<ul style=\"padding-left:20px;\">\r\n\t\t<li>A string $s$ of length&nbsp;$K$, also consisting only of uppercase English letters, is drawn as the winning string.<\/li>\r\n\t\t<li>You earn a score equal to the number of all substrings in your purchased string that are exactly equal to $s$. The total score is the sum of these counts across all the strings you wrote when purchasing the lottery.<\/li>\r\n\t\t<li>A substring of a string is a contiguous sequence of its characters. For example,&nbsp;<span style=\"color:#000000;\"><code>aex<\/code><\/span>,&nbsp;<span style=\"color:#000000;\"><code>joo<\/code><\/span>, and <span style=\"color:#000000;\"><code>ekj<\/code><\/span> are substrings of <span style=\"color:#000000;\"><code>baekjoon<\/code><\/span>, while <span style=\"color:#000000;\"><code>bak<\/code><\/span>,&nbsp;<span style=\"color:#000000;\"><code>p<\/code><\/span>, and <span style=\"color:#000000;\"><code>oone<\/code><\/span> are not.<\/li>\r\n\t<\/ul>\r\n\t<\/li>\r\n<\/ul>\r\n\r\n<p>Dalgu bought one lottery ticket this week. Determine the maximum total score Dalgu can obtain from this week&#39;s lottery draw.<\/p>\r\n","input":"<p>The first line contains two integers $L$ and $N$, separated by a space, representing the length of each string in the lotto and the number of strings, respectively ($1 \\le L \\le 100$; $1 \\le N \\le 20$)<\/p>\r\n\r\n<p>The next $N&amp; lines each contain one string written by Dalgu for the lotto he purchased this week. (Each given string consists only of uppercase English letters.)<\/p>\r\n\r\n<p>The $N+2$th line contains an integer $K$. ($1 \\leq K \\leq L$)<\/p>\r\n","output":"<p>Print the maximum total score that Dalgu can obtain from this weeks lotto draw on the first line.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"English","sample_explain_1":"<p>If the string <code><span style=\"color:#e74c3c;\">AB<\/span><\/code> is drawn, you can score $3$ points from <span style=\"color:#e74c3c;\"><code>ABABAB<\/code><\/span>, 1 point from <code>A<span style=\"color:#e74c3c;\">AB<\/span>BAA<\/code>, $1$ point from <code>A<span style=\"color:#e74c3c;\">AB<\/span>BBB<\/code>, and 2 points from <code><span style=\"color:#e74c3c;\">AB<\/span>BA<span style=\"color:#e74c3c;\">AB<\/span><\/code>, for a total of $7$ points. This is the maximum possible score.<\/p>\r\n","sample_explain_2":"<p>If the string <span style=\"color:#e74c3c;\"><code>ZZ<\/code><\/span> is drawn, you can score 3 points from <span style=\"color:#e74c3c;\"><code>ZZZZ<\/code><\/span> by matching <code><span style=\"color:#e74c3c;\">ZZ<\/span>ZZ<\/code>, <code>Z<span style=\"color:#e74c3c;\">ZZ<\/span>Z<\/code>, and <code>ZZ<span style=\"color:#e74c3c;\">ZZ<\/span><\/code>.<\/p>\r\n"}]