시간 제한 메모리 제한 제출 정답 맞은 사람 정답 비율
1 초 128 MB 23 10 6 46.154%

문제

중세 기사 시대에, 사악한 조롱에 대항하는 정신력, 즉 '멘탈'은 아주 중요한 것이었다.

킹 현우는 자신의 노예들이 약한 멘탈을 갖기를 바라지 않았다. 그래서 자신의 엄청난 코딩 능력으로 트레이닝용 도발 봇을 만들어냈다.

하지만 현우는 아직 인공지능 수업을 듣지 않았고, 아는 것이라곤 오토마타 1단원 뿐이었기 때문에 같은 상태에서 같은 입력을 받는다면 항상 같은 행동을 하는 것이 보장되는 봇 하나를 짜는 것이 고작이었다.

현우가 만든 도발 봇은 아래의 테이블과, 이어 설명할 몇 가지 규칙에 따라 행동한다.

<taunt> ::= <sentence> | <taunt> <sentence> | <noun>! | <sentence>
<sentence> ::= <past-rel> <noun-phrase> | <present-rel> <noun-phrase> | <past-rel> <article> <noun> 
<noun-phrase> ::= <article> <modified-noun>
<modified-noun> ::= <noun> | <modifier> <noun>
<modifier> ::= <adjective> | <adverb> <adjective>
<present-rel> ::= your <present-person> <present-verb>
<past-rel> ::= your <past-person> <past-verb>
<present-person> ::= steed | king | first-born
<past-person> ::= mother | father | grandmother | grandfather | godfather
<noun> ::= hamster | coconut | duck | herring | newt | peril | chicken | vole | parrot | mouse | twit 
<present-verb> ::= is | “masquerades as”
<past-verb> ::= was | personified
<article> ::= a
<adjective> ::= silly | wicked | sordid | naughty | repulsive | malodorous | ill-tempered
<adverb> ::= conspicuously | categorically | positively | cruelly | incontrovertibly

쌍따옴표 안에 있는 문구는 항상 하나의 단어로 취급된다.

위의 표를 읽는 법을 모른다면 이 링크를 참고하자.

봇은 위의 테이블을 참조하여, 아래와 같은 규칙으로 도발을 한다.

  • '단어'란, 최소 한 개의 영어 알파벳을 포함하고 있으며, 다른 단어와 최소 한 개 이상의 공백 문자로 구분되어 있는 연속된 문자열을 의미한다.
  • 봇은 우선 상대의 말을 모두 듣는다. 그 이후, 상대의 말에 몇 개의 단어가 있는지에 따라 도발의 수가 결정된다. 상대가 3개의 단어를 말할 때마다 한 개의 도발을 하며, 만일 상대가 말한 단어의 수가 3으로 나누어 떨어지지 않는다면 한 번의 도발을 더 한다.
  • 기본적으로 봇이 하는 도발은 위의 테이블에서 <taunt> 하나로 시작하여 재귀적으로 계속 확장하게 된다. 이 때, 자세히 보면 <taunt>가 다시 <taunt>를 만들게 되어 한 문장에 도발이 두 번 들어가는 경우가 있는데, 이런 경우엔 도발을 두 번 한 것으로 세야 한다. 만일 상대가 말한 문장이 4개의 단어로 이루어져 있고, 봇이 한 문장에 도발을 두 번 하게 된다면, 그대로 봇은 임무를 다한 것이다.
  • 어떤 기호에 대한 표현식이 총 N가지이고, 이 기호를 지금 K번째로 만났으면 ((K-1) mod N) + 1 번째 선택지를 택한다. 이 선택은 모든 기호에 대해 독립적이다. 예를 들어, 첫 번째 도발은
    <taunt>
    => <sentence>
    => <past-rel> <noun-phrase>
    => your <past-person> <past-verb> <article> <modified-noun>
    => your mother was a <noun>
    => your mother was a hamster
    가 되며, 두 번째 도발의 첫 확장 부분은
    <taunt>
    => <taunt> <sentence>
    => <noun>! <present-rel> <noun-phrase>
    => ...
    이 될 것이다.
  • 이외에 항상 적용되는 특별한 예외 규칙으로, 상대가 말한 문장에 t-h-e-h-o-l-y-g-r-a-i-l (대소문자 구분 없음) 의 12글자가 순서대로 (비연속적이어도 상관 없음) 등장한다면, 봇이 처음으로 만드는 도발은 "(A childish hand gesture)." 가 되어야 한다. 이 도발은 선택지를 거치지 않기 때문에 각 기호들의 선택 상태에 아무 영향을 미치지 않으며, 한 개의 도발로 카운트된다.

킹 현우는 이 복잡한 봇을 통해 노예들을 훈련시킬 것이다.

킹 현우의 도발 봇이 어떻게 행동하게 될 지 시뮬레이션해 보자.

입력

입력은 임의의 여러 줄로 구성된다.

각 줄은 봇의 상대가 말한 내용으로 구성되어 있으며, 항상 알파벳 대소문자, 숫자, ",.-!?", 공백으로만 이루어져 있다.

모든 라인은 최소 1개, 최대 72개의 문자로 이루어져 있으며, 단어는 항상 하나 이상의 공백으로 구분되어져 있다.

모든 라인에 대해, 단어가 0개인 경우는 없다.

출력

각 입력에 대해, 아래와 같이 출력한다.

  • "Kight:", 공백 문자 하나, 입력된 문장을 순서대로 출력한다. 이 때, 입력에 만일 1개를 초과하는 연속된 공백 문자가 있다면 모두 단 하나의 공백 문자로 대체되어야 한다.
  • "Taunter:", 공백 문자 하나, 문제에서 설명한 도발, 마침표 하나를 필요한 도발 수만큼 순서대로 출력한다. 각 단어는 항상 하나의 공백 문자로 구분되어야 한다.
  • 위의 두 출력단이 끝나면, 빈 줄 하나를 추가로 출력한다.

모든 도발은 대문자로 시작해야 하며, 추가적인 공백 문자가 있어서는 안 된다.

예제 입력 1

Hello! 
Are you feeling alright? 
Is there someone else I could talk to? 
Anyone at    all? 
We seek the holy grail . . .

예제 출력 1

Knight: Hello! 
Taunter: Your mother was a hamster. 

Knight: Are you feeling alright? 
Taunter: Coconut! Your steed is a silly duck. 

Knight: Is there someone else I could talk to? 
Taunter: Your father personified a herring. 
Taunter: Your grandmother was a newt. 
Taunter: Peril! Your king masquerades as a conspicuously wicked chicken. 

Knight: Anyone at all? 
Taunter: Your grandfather personified a vole. 

Knight: We seek the holy grail . . . 
Taunter: (A childish hand gesture). 
Taunter: Your godfather was a parrot.
[{"problem_id":"9167","problem_lang":"0","title":"\ub3c4\ubc1c \ubd07","description":"<p>\uc911\uc138 \uae30\uc0ac \uc2dc\ub300\uc5d0, \uc0ac\uc545\ud55c \uc870\ub871\uc5d0 \ub300\ud56d\ud558\ub294 \uc815\uc2e0\ub825, \uc989 &#39;\uba58\ud0c8&#39;\uc740 \uc544\uc8fc \uc911\uc694\ud55c \uac83\uc774\uc5c8\ub2e4.<\/p>\r\n\r\n<p>\ud0b9 \ud604\uc6b0\ub294 \uc790\uc2e0\uc758 \ub178\uc608\ub4e4\uc774 \uc57d\ud55c \uba58\ud0c8\uc744 \uac16\uae30\ub97c \ubc14\ub77c\uc9c0 \uc54a\uc558\ub2e4. \uadf8\ub798\uc11c \uc790\uc2e0\uc758 \uc5c4\uccad\ub09c \ucf54\ub529 \ub2a5\ub825\uc73c\ub85c \ud2b8\ub808\uc774\ub2dd\uc6a9 \ub3c4\ubc1c \ubd07\uc744 \ub9cc\ub4e4\uc5b4\ub0c8\ub2e4.<\/p>\r\n\r\n<p>\ud558\uc9c0\ub9cc \ud604\uc6b0\ub294 \uc544\uc9c1 \uc778\uacf5\uc9c0\ub2a5 \uc218\uc5c5\uc744 \ub4e3\uc9c0 \uc54a\uc558\uace0, \uc544\ub294 \uac83\uc774\ub77c\uace4 \uc624\ud1a0\ub9c8\ud0c0 1\ub2e8\uc6d0 \ubfd0\uc774\uc5c8\uae30 \ub54c\ubb38\uc5d0 \uac19\uc740 \uc0c1\ud0dc\uc5d0\uc11c \uac19\uc740 \uc785\ub825\uc744 \ubc1b\ub294\ub2e4\uba74 \ud56d\uc0c1 \uac19\uc740 \ud589\ub3d9\uc744 \ud558\ub294 \uac83\uc774 \ubcf4\uc7a5\ub418\ub294 \ubd07 \ud558\ub098\ub97c \uc9dc\ub294 \uac83\uc774 \uace0\uc791\uc774\uc5c8\ub2e4.<\/p>\r\n\r\n<p>\ud604\uc6b0\uac00 \ub9cc\ub4e0 \ub3c4\ubc1c \ubd07\uc740 \uc544\ub798\uc758 \ud14c\uc774\ube14\uacfc, \uc774\uc5b4 \uc124\uba85\ud560 \uba87 \uac00\uc9c0 \uaddc\uce59\uc5d0 \ub530\ub77c \ud589\ub3d9\ud55c\ub2e4.<\/p>\r\n\r\n<pre>\r\n&lt;taunt&gt; ::= &lt;sentence&gt; | &lt;taunt&gt; &lt;sentence&gt; | &lt;noun&gt;! | &lt;sentence&gt;\r\n&lt;sentence&gt; ::= &lt;past-rel&gt; &lt;noun-phrase&gt; | &lt;present-rel&gt; &lt;noun-phrase&gt; | &lt;past-rel&gt; &lt;article&gt; &lt;noun&gt; \r\n&lt;noun-phrase&gt; ::= &lt;article&gt; &lt;modified-noun&gt;\r\n&lt;modified-noun&gt; ::= &lt;noun&gt; | &lt;modifier&gt; &lt;noun&gt;\r\n&lt;modifier&gt; ::= &lt;adjective&gt; | &lt;adverb&gt; &lt;adjective&gt;\r\n&lt;present-rel&gt; ::= your &lt;present-person&gt; &lt;present-verb&gt;\r\n&lt;past-rel&gt; ::= your &lt;past-person&gt; &lt;past-verb&gt;\r\n&lt;present-person&gt; ::= steed | king | first-born\r\n&lt;past-person&gt; ::= mother | father | grandmother | grandfather | godfather\r\n&lt;noun&gt; ::= hamster | coconut | duck | herring | newt | peril | chicken | vole | parrot | mouse | twit \r\n&lt;present-verb&gt; ::= is | &ldquo;masquerades as&rdquo;\r\n&lt;past-verb&gt; ::= was | personified\r\n&lt;article&gt; ::= a\r\n&lt;adjective&gt; ::= silly | wicked | sordid | naughty | repulsive | malodorous | ill-tempered\r\n&lt;adverb&gt; ::= conspicuously | categorically | positively | cruelly | incontrovertibly<\/pre>\r\n\r\n<p>\uc30d\ub530\uc634\ud45c \uc548\uc5d0 \uc788\ub294 \ubb38\uad6c\ub294 \ud56d\uc0c1 \ud558\ub098\uc758 \ub2e8\uc5b4\ub85c \ucde8\uae09\ub41c\ub2e4.<\/p>\r\n\r\n<p>\uc704\uc758 \ud45c\ub97c \uc77d\ub294 \ubc95\uc744 \ubaa8\ub978\ub2e4\uba74&nbsp;<a href=\"https:\/\/ko.wikipedia.org\/wiki\/%EB%B0%B0%EC%BB%A4%EC%8A%A4-%EB%82%98%EC%9A%B0%EB%A5%B4_%ED%91%9C%EA%B8%B0%EB%B2%95\">\uc774 \ub9c1\ud06c<\/a>\ub97c \ucc38\uace0\ud558\uc790.<\/p>\r\n\r\n<p>\ubd07\uc740 \uc704\uc758 \ud14c\uc774\ube14\uc744 \ucc38\uc870\ud558\uc5ec, \uc544\ub798\uc640 \uac19\uc740 \uaddc\uce59\uc73c\ub85c \ub3c4\ubc1c\uc744 \ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>&#39;\ub2e8\uc5b4&#39;\ub780, \ucd5c\uc18c \ud55c \uac1c\uc758 \uc601\uc5b4 \uc54c\ud30c\ubcb3\uc744 \ud3ec\ud568\ud558\uace0 \uc788\uc73c\uba70, \ub2e4\ub978 \ub2e8\uc5b4\uc640 \ucd5c\uc18c \ud55c \uac1c \uc774\uc0c1\uc758 \uacf5\ubc31 \ubb38\uc790\ub85c \uad6c\ubd84\ub418\uc5b4 \uc788\ub294 \uc5f0\uc18d\ub41c \ubb38\uc790\uc5f4\uc744 \uc758\ubbf8\ud55c\ub2e4.<\/li>\r\n\t<li>\ubd07\uc740 \uc6b0\uc120 \uc0c1\ub300\uc758 \ub9d0\uc744 \ubaa8\ub450 \ub4e3\ub294\ub2e4. \uadf8 \uc774\ud6c4, \uc0c1\ub300\uc758 \ub9d0\uc5d0 \uba87 \uac1c\uc758 \ub2e8\uc5b4\uac00 \uc788\ub294\uc9c0\uc5d0 \ub530\ub77c \ub3c4\ubc1c\uc758 \uc218\uac00 \uacb0\uc815\ub41c\ub2e4. \uc0c1\ub300\uac00 3\uac1c\uc758 \ub2e8\uc5b4\ub97c \ub9d0\ud560 \ub54c\ub9c8\ub2e4 \ud55c \uac1c\uc758 \ub3c4\ubc1c\uc744 \ud558\uba70, \ub9cc\uc77c \uc0c1\ub300\uac00 \ub9d0\ud55c \ub2e8\uc5b4\uc758 \uc218\uac00 3\uc73c\ub85c \ub098\ub204\uc5b4 \ub5a8\uc5b4\uc9c0\uc9c0 \uc54a\ub294\ub2e4\uba74 \ud55c \ubc88\uc758 \ub3c4\ubc1c\uc744 \ub354 \ud55c\ub2e4.<\/li>\r\n\t<li>\uae30\ubcf8\uc801\uc73c\ub85c \ubd07\uc774 \ud558\ub294 \ub3c4\ubc1c\uc740 \uc704\uc758 \ud14c\uc774\ube14\uc5d0\uc11c &lt;taunt&gt; \ud558\ub098\ub85c \uc2dc\uc791\ud558\uc5ec \uc7ac\uadc0\uc801\uc73c\ub85c \uacc4\uc18d \ud655\uc7a5\ud558\uac8c \ub41c\ub2e4. \uc774 \ub54c, \uc790\uc138\ud788 \ubcf4\uba74 &lt;taunt&gt;\uac00 \ub2e4\uc2dc &lt;taunt&gt;\ub97c \ub9cc\ub4e4\uac8c \ub418\uc5b4 \ud55c \ubb38\uc7a5\uc5d0 \ub3c4\ubc1c\uc774 \ub450 \ubc88 \ub4e4\uc5b4\uac00\ub294 \uacbd\uc6b0\uac00 \uc788\ub294\ub370, \uc774\ub7f0 \uacbd\uc6b0\uc5d4 \ub3c4\ubc1c\uc744 \ub450 \ubc88 \ud55c \uac83\uc73c\ub85c \uc138\uc57c \ud55c\ub2e4. \ub9cc\uc77c \uc0c1\ub300\uac00 \ub9d0\ud55c \ubb38\uc7a5\uc774 4\uac1c\uc758 \ub2e8\uc5b4\ub85c \uc774\ub8e8\uc5b4\uc838 \uc788\uace0, \ubd07\uc774 \ud55c \ubb38\uc7a5\uc5d0 \ub3c4\ubc1c\uc744 \ub450 \ubc88 \ud558\uac8c \ub41c\ub2e4\uba74, \uadf8\ub300\ub85c \ubd07\uc740 \uc784\ubb34\ub97c \ub2e4\ud55c \uac83\uc774\ub2e4.<\/li>\r\n\t<li>\uc5b4\ub5a4 \uae30\ud638\uc5d0 \ub300\ud55c \ud45c\ud604\uc2dd\uc774 \ucd1d N\uac00\uc9c0\uc774\uace0, \uc774 \uae30\ud638\ub97c \uc9c0\uae08 K\ubc88\uc9f8\ub85c \ub9cc\ub0ac\uc73c\uba74 ((K-1) mod N) + 1 \ubc88\uc9f8 \uc120\ud0dd\uc9c0\ub97c \ud0dd\ud55c\ub2e4. \uc774 \uc120\ud0dd\uc740 \ubaa8\ub4e0 \uae30\ud638\uc5d0 \ub300\ud574 \ub3c5\ub9bd\uc801\uc774\ub2e4. \uc608\ub97c \ub4e4\uc5b4, \uccab \ubc88\uc9f8 \ub3c4\ubc1c\uc740<br \/>\r\n\t&lt;taunt&gt;<br \/>\r\n\t=&gt; &lt;sentence&gt;<br \/>\r\n\t=&gt; &lt;past-rel&gt; &lt;noun-phrase&gt;<br \/>\r\n\t=&gt; your &lt;past-person&gt; &lt;past-verb&gt; &lt;article&gt; &lt;modified-noun&gt;<br \/>\r\n\t=&gt; your mother was a &lt;noun&gt;<br \/>\r\n\t=&gt; your mother was a hamster<br \/>\r\n\t\uac00 \ub418\uba70, \ub450 \ubc88\uc9f8 \ub3c4\ubc1c\uc758 \uccab \ud655\uc7a5 \ubd80\ubd84\uc740<br \/>\r\n\t&lt;taunt&gt;<br \/>\r\n\t=&gt; &lt;taunt&gt; &lt;sentence&gt;<br \/>\r\n\t=&gt; &lt;noun&gt;!&nbsp;&lt;present-rel&gt; &lt;noun-phrase&gt;<br \/>\r\n\t=&gt; ...<br \/>\r\n\t\uc774 \ub420 \uac83\uc774\ub2e4.<\/li>\r\n\t<li>\uc774\uc678\uc5d0 \ud56d\uc0c1 \uc801\uc6a9\ub418\ub294 \ud2b9\ubcc4\ud55c \uc608\uc678 \uaddc\uce59\uc73c\ub85c, \uc0c1\ub300\uac00 \ub9d0\ud55c \ubb38\uc7a5\uc5d0 t-h-e-h-o-l-y-g-r-a-i-l (\ub300\uc18c\ubb38\uc790 \uad6c\ubd84 \uc5c6\uc74c) \uc758 12\uae00\uc790\uac00 \uc21c\uc11c\ub300\ub85c (\ube44\uc5f0\uc18d\uc801\uc774\uc5b4\ub3c4 \uc0c1\uad00 \uc5c6\uc74c) \ub4f1\uc7a5\ud55c\ub2e4\uba74, \ubd07\uc774 \ucc98\uc74c\uc73c\ub85c \ub9cc\ub4dc\ub294 \ub3c4\ubc1c\uc740 &quot;(A childish hand gesture).&quot; \uac00 \ub418\uc5b4\uc57c \ud55c\ub2e4. \uc774 \ub3c4\ubc1c\uc740 \uc120\ud0dd\uc9c0\ub97c \uac70\uce58\uc9c0 \uc54a\uae30 \ub54c\ubb38\uc5d0 \uac01 \uae30\ud638\ub4e4\uc758 \uc120\ud0dd \uc0c1\ud0dc\uc5d0 \uc544\ubb34 \uc601\ud5a5\uc744 \ubbf8\uce58\uc9c0 \uc54a\uc73c\uba70, \ud55c \uac1c\uc758 \ub3c4\ubc1c\ub85c \uce74\uc6b4\ud2b8\ub41c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ud0b9 \ud604\uc6b0\ub294 \uc774 \ubcf5\uc7a1\ud55c \ubd07\uc744 \ud1b5\ud574 \ub178\uc608\ub4e4\uc744 \ud6c8\ub828\uc2dc\ud0ac \uac83\uc774\ub2e4.<\/p>\r\n\r\n<p>\ud0b9 \ud604\uc6b0\uc758 \ub3c4\ubc1c \ubd07\uc774 \uc5b4\ub5bb\uac8c \ud589\ub3d9\ud558\uac8c \ub420 \uc9c0 \uc2dc\ubbac\ub808\uc774\uc158\ud574 \ubcf4\uc790.<\/p>\r\n","input":"<p>\uc785\ub825\uc740 \uc784\uc758\uc758 \uc5ec\ub7ec \uc904\ub85c \uad6c\uc131\ub41c\ub2e4.<\/p>\r\n\r\n<p>\uac01 \uc904\uc740 \ubd07\uc758 \uc0c1\ub300\uac00 \ub9d0\ud55c \ub0b4\uc6a9\uc73c\ub85c \uad6c\uc131\ub418\uc5b4 \uc788\uc73c\uba70, \ud56d\uc0c1 \uc54c\ud30c\ubcb3 \ub300\uc18c\ubb38\uc790, \uc22b\uc790, &quot;,.-!?&quot;, \uacf5\ubc31\uc73c\ub85c\ub9cc \uc774\ub8e8\uc5b4\uc838 \uc788\ub2e4.<\/p>\r\n\r\n<p>\ubaa8\ub4e0 \ub77c\uc778\uc740 \ucd5c\uc18c 1\uac1c, \ucd5c\ub300 72\uac1c\uc758 \ubb38\uc790\ub85c \uc774\ub8e8\uc5b4\uc838 \uc788\uc73c\uba70, \ub2e8\uc5b4\ub294 \ud56d\uc0c1 \ud558\ub098 \uc774\uc0c1\uc758 \uacf5\ubc31\uc73c\ub85c \uad6c\ubd84\ub418\uc5b4\uc838 \uc788\ub2e4.<\/p>\r\n\r\n<p>\ubaa8\ub4e0 \ub77c\uc778\uc5d0 \ub300\ud574, \ub2e8\uc5b4\uac00 0\uac1c\uc778 \uacbd\uc6b0\ub294 \uc5c6\ub2e4.<\/p>\r\n","output":"<p>\uac01 \uc785\ub825\uc5d0 \ub300\ud574, \uc544\ub798\uc640 \uac19\uc774 \ucd9c\ub825\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>&quot;Kight:&quot;, \uacf5\ubc31 \ubb38\uc790 \ud558\ub098, \uc785\ub825\ub41c \ubb38\uc7a5\uc744 \uc21c\uc11c\ub300\ub85c \ucd9c\ub825\ud55c\ub2e4. \uc774 \ub54c, \uc785\ub825\uc5d0 \ub9cc\uc77c 1\uac1c\ub97c \ucd08\uacfc\ud558\ub294 \uc5f0\uc18d\ub41c \uacf5\ubc31 \ubb38\uc790\uac00 \uc788\ub2e4\uba74 \ubaa8\ub450 \ub2e8 \ud558\ub098\uc758 \uacf5\ubc31 \ubb38\uc790\ub85c \ub300\uccb4\ub418\uc5b4\uc57c \ud55c\ub2e4.<\/li>\r\n\t<li>&quot;Taunter:&quot;, \uacf5\ubc31 \ubb38\uc790 \ud558\ub098, \ubb38\uc81c\uc5d0\uc11c \uc124\uba85\ud55c \ub3c4\ubc1c, \ub9c8\uce68\ud45c \ud558\ub098\ub97c \ud544\uc694\ud55c \ub3c4\ubc1c \uc218\ub9cc\ud07c \uc21c\uc11c\ub300\ub85c \ucd9c\ub825\ud55c\ub2e4. \uac01 \ub2e8\uc5b4\ub294 \ud56d\uc0c1 \ud558\ub098\uc758 \uacf5\ubc31 \ubb38\uc790\ub85c \uad6c\ubd84\ub418\uc5b4\uc57c \ud55c\ub2e4.<\/li>\r\n\t<li>\uc704\uc758 \ub450 \ucd9c\ub825\ub2e8\uc774 \ub05d\ub098\uba74, \ube48 \uc904 \ud558\ub098\ub97c \ucd94\uac00\ub85c \ucd9c\ub825\ud55c\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\ubaa8\ub4e0 \ub3c4\ubc1c\uc740 \ub300\ubb38\uc790\ub85c \uc2dc\uc791\ud574\uc57c \ud558\uba70, \ucd94\uac00\uc801\uc778 \uacf5\ubc31 \ubb38\uc790\uac00 \uc788\uc5b4\uc11c\ub294 \uc548 \ub41c\ub2e4.<\/p>\r\n","hint":"","original":"0","problem_lang_code":"\ud55c\uad6d\uc5b4"},{"problem_id":"9167","problem_lang":"1","title":"Taunt Generation Simulator","description":"<p>In all the annals of knighthood, no personality trait has been in more dire need than the fortitude to withstand the diplomatically deleterious effects of a vicious, relentless taunting. Tasked with strengthening the mental endurance of Camelot&rsquo;s knights, King Arthur&#39;s court decided that instructional taunting must be applied, yet it could not be delivered by the chivalrous administration. Thus, Sir Lancelot commanded a local anarcho-syndicalist peasant to write a program that generates taunts (a.k.a. mudslinging) thereby producing a script to test the patience of knights in a training environment. To prevent unbridled creativity in taunting from spoiling the otherwise stately proceedings of a nobleman&rsquo;s education, the following rules designed by committee (The Round Table) must be adhered to:<\/p>\r\n\r\n<pre>\r\n&lt;taunt&gt; ::= &lt;sentence&gt; | &lt;taunt&gt; &lt;sentence&gt; | &lt;noun&gt;! | &lt;sentence&gt;\r\n&lt;sentence&gt; ::= &lt;past-rel&gt; &lt;noun-phrase&gt; | &lt;present-rel&gt; &lt;noun-phrase&gt; | &lt;past-rel&gt; &lt;article&gt; &lt;noun&gt; \r\n&lt;noun-phrase&gt; ::= &lt;article&gt; &lt;modified-noun&gt;\r\n&lt;modified-noun&gt; ::= &lt;noun&gt; | &lt;modifier&gt; &lt;noun&gt;\r\n&lt;modifier&gt; ::= &lt;adjective&gt; | &lt;adverb&gt; &lt;adjective&gt;\r\n&lt;present-rel&gt; ::= your &lt;present-person&gt; &lt;present-verb&gt;\r\n&lt;past-rel&gt; ::= your &lt;past-person&gt; &lt;past-verb&gt;\r\n&lt;present-person&gt; ::= steed | king | first-born\r\n&lt;past-person&gt; ::= mother | father | grandmother | grandfather | godfather\r\n&lt;noun&gt; ::= hamster | coconut | duck | herring | newt | peril | chicken | vole | parrot | mouse | twit \r\n&lt;present-verb&gt; ::= is | &ldquo;masquerades as&rdquo;\r\n&lt;past-verb&gt; ::= was | personified\r\n&lt;article&gt; ::= a\r\n&lt;adjective&gt; ::= silly | wicked | sordid | naughty | repulsive | malodorous | ill-tempered\r\n&lt;adverb&gt; ::= conspicuously | categorically | positively | cruelly | incontrovertibly<\/pre>\r\n\r\n<p>Note that all phrases in double quotes are to be treated as one word for taunt simulation output.<\/p>\r\n\r\n<p>The number of taunts elicited at any given time is derived from the number of words spoken by the knight. For every three words (or fraction thereof) delivered by the knight, the generator produces one or more taunts in a theater-style script format. In the event that 2 taunts must be produced on a single line, they will be counted as 2 taunts towards the total required. By a mandate from the masses, a word will always contain at least one alphabetic character, and will be separated from other words by at least 1 space.<\/p>\r\n\r\n<p>In exception to the above rules, whenever the program finds the holy grail, which is to say, the letters t-h-e-h-o-l-y-g-r-a-i-l (case insensitive) in that order in a line of input, then the first taunt generated will be displayed by the program as &ldquo;(A childish hand gesture)&rdquo;.<\/p>\r\n\r\n<p>To ensure all royal quality assurance criteria are met, the program must be demonstrated by a simulation showing the taunts produced from a series of inputs. Each taunt is generated by applying the taunt generation rules until all of the &lt;...&gt; have been replaced with appropriate words. In most cases, you will face a choice of alternate rules for expanding a phrase name. In these cases, you should make a choice as follows: Suppose that this is the k<sup>th<\/sup> such choice that you have faced for that rule since the start of program execution, and that you must choose one of n rules for expanding a given kind of phrase. Let the rules for that phrase be numbered from 1...n in the order of appearance above, and then choose rule number ((k-1) mod n) + 1.<\/p>\r\n\r\n<p>Well, get on with it!<\/p>\r\n","input":"<p>The input will consist of an unspecified number of lines. Each line will contain a statement uttered by a knight consisting of letters, digits, the characters &quot;,.-!?&quot; and whitespace. Each line of input will be more than 1 character and less than 72 characters in length. All words will be separated by whitespace. Each statement will contain at least one word.<\/p>\r\n","output":"<p>For every line of input, print a block of output containing the following:<\/p>\r\n\r\n<ul>\r\n\t<li>A single line containing &quot;Knight:&quot;, a space, and the input. Any appearance of whitespace inside the input will be replaced by a single space.<\/li>\r\n\t<li>All taunts (as explained in the above rules) prefaced by &quot;Taunter:&quot; and a space, the taunt, and a period. Each word should be separated from neighboring words by a single space.<\/li>\r\n\t<li>A blank line&nbsp;<\/li>\r\n<\/ul>\r\n\r\n<p>Each taunt should begin with a capital letter, and no extra characters should be added.<\/p>\r\n","hint":"","original":"1","problem_lang_code":"\uc601\uc5b4"}]