시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 128 MB42517411838.562%

문제

옛날 옛적에 수학을 공부하는 사람들만 사는 나라가 있었다. 이 나라에 살고있는 상근이와 창영이는 자명한 문장에 대해서 토론을 하고 있었다.

자명한 문장에는 숫자를 하나만 포함하고 있으며, 그 숫자는 문장을 이루는 글자의 개수와 같다. 예를 들면, "This sentence has thirtyone letters.”, “Blah blah seventeen”과 같다.

상근이는 창영이에게 자명한 문장에서 숫자만 지운 문장을 주었다. 창영이는 가장 작은 수를 문장에 넣어 올바른 자명한 문장을 만드는 프로그램을 작성하려고 한다.

문장은 word1 word2 word3 ... \$ word_n-1 word_n과 같은 형식으로 이루어져 있고, \$는 숫자를 넣을 곳을 나타낸다.

예를 들어, 상근이는 “this sentence has thirtyone letters”를 “this sentence has \$ letters”로 바꾸어 창영이에게 전달해준다.

숫자는 다음과 같은 규칙을 지키면서 써야한다.

  • 1부터 10까지 숫자는 “one”, “two”, “three”, “four”, “five”, “six”, “seven”, “eight”, “nine”, “ten”로 쓴다.
  • 11부터 19까지 숫자는 “eleven”, “twelve”, “thirteen”, “fourteen”, “fifteen”, “sixteen”, “seventeen”, “eighteen”, “nineteen”로 쓴다.
  • 나머지 두 자리 숫자는 십의 자리를 쓰고 일의 자리를 쓴다. 만약 일의 자리가 0인 경우에는 십의 자리만 쓴다.
  • 십의 자리의 경우에 2부터 9까지는 “twenty”, “thirty”, “forty”, “fifty”, “sixty”, “seventy”, “eighty”, “ninety”로 쓴다.
  • 세 자리 숫자는 백의 자리를 쓰고, 나머지 두 자리를 쓴다. 두 자리가 0인 경우에는 백의 자리만 쓰면 된다.
  • 백의 자리의 경우에 1부터 9까지는 “onehundred”, “twohundred”, “threehundred”, “fourhundred”, “fivehundred”, “sixhundred”, “sevenhundred”, “eighthundred”, “ninehundred”로 쓴다.
  • 항상 세자리 이내로 문제를 풀 수 있다.

아래와 같이 숫자를 쓸 수 있다.

  • 68 = “sixty” + “eight” = “sixtyeight” 
  • 319 = “threehundred” + “nineteen” = “threehundrednineteen” 
  • 530 = “fivehundred” + “thirty” = “fivehundredthirty” 
  • 971 = “ninehundred” + “seventy” + “one” = “ninehundredseventyone”

입력

첫째 줄에 문장을 이루는 단어의 수 N (1 ≤ N ≤ 20)가 주어진다.

다음 N개 줄에는 문장을 이루는 단어가 주어진다. 입력으로 주어지는 단어는 길이가 최대 50이며 알파벳 소문자로만 이루어져 있다. 입력으로 주어지는 단어 중에 숫자를 나타내는 단어는 없다.

\$는 하나만 주어진다.

출력

첫째 줄에 문장을 출력한다. 항상 답이 존재하는 경우만 주어지며, 숫자는 항상 1000보다 작다.

예제 입력 1

5
this
sentence
has
$
letters

예제 출력 1

this sentence has thirtyone letters

예제 입력 2

7
$
is
the
number
of
letters
here

예제 출력 2

thirty is the number of letters here

예제 입력 3

5
the
letters
are
$
potato

예제 출력 3

the letters are twentynine potato
[{"problem_id":"9627","problem_lang":"0","title":"\ubb38\uc7a5","description":"<p>\uc61b\ub0a0 \uc61b\uc801\uc5d0 \uc218\ud559\uc744 \uacf5\ubd80\ud558\ub294 \uc0ac\ub78c\ub4e4\ub9cc \uc0ac\ub294 \ub098\ub77c\uac00 \uc788\uc5c8\ub2e4. \uc774 \ub098\ub77c\uc5d0 \uc0b4\uace0\uc788\ub294 \uc0c1\uadfc\uc774\uc640 \ucc3d\uc601\uc774\ub294 \uc790\uba85\ud55c \ubb38\uc7a5\uc5d0 \ub300\ud574\uc11c \ud1a0\ub860\uc744 \ud558\uace0 \uc788\uc5c8\ub2e4.<\/p>\r\n\r\n<p>\uc790\uba85\ud55c \ubb38\uc7a5\uc5d0\ub294 \uc22b\uc790\ub97c \ud558\ub098\ub9cc \ud3ec\ud568\ud558\uace0 \uc788\uc73c\uba70, \uadf8 \uc22b\uc790\ub294 \ubb38\uc7a5\uc744 \uc774\ub8e8\ub294 \uae00\uc790\uc758 \uac1c\uc218\uc640 \uac19\ub2e4. \uc608\ub97c \ub4e4\uba74, &quot;This sentence has thirtyone letters.&rdquo;, &ldquo;Blah blah seventeen&rdquo;\uacfc \uac19\ub2e4.<\/p>\r\n\r\n<p>\uc0c1\uadfc\uc774\ub294 \ucc3d\uc601\uc774\uc5d0\uac8c \uc790\uba85\ud55c \ubb38\uc7a5\uc5d0\uc11c \uc22b\uc790\ub9cc \uc9c0\uc6b4 \ubb38\uc7a5\uc744 \uc8fc\uc5c8\ub2e4. \ucc3d\uc601\uc774\ub294 \uac00\uc7a5 \uc791\uc740 \uc218\ub97c \ubb38\uc7a5\uc5d0 \ub123\uc5b4 \uc62c\ubc14\ub978 \uc790\uba85\ud55c \ubb38\uc7a5\uc744 \ub9cc\ub4dc\ub294 \ud504\ub85c\uadf8\ub7a8\uc744 \uc791\uc131\ud558\ub824\uace0 \ud55c\ub2e4.<\/p>\r\n\r\n<p>\ubb38\uc7a5\uc740 word1 word2 word3 ... \\$ word_n-1 word_n\uacfc \uac19\uc740 \ud615\uc2dd\uc73c\ub85c \uc774\ub8e8\uc5b4\uc838 \uc788\uace0, \\$\ub294 \uc22b\uc790\ub97c \ub123\uc744 \uacf3\uc744 \ub098\ud0c0\ub0b8\ub2e4.<\/p>\r\n\r\n<p>\uc608\ub97c \ub4e4\uc5b4, \uc0c1\uadfc\uc774\ub294 &ldquo;this sentence has thirtyone letters&rdquo;\ub97c &ldquo;this sentence has \\$ letters&rdquo;\ub85c \ubc14\uafb8\uc5b4 \ucc3d\uc601\uc774\uc5d0\uac8c \uc804\ub2ec\ud574\uc900\ub2e4.<\/p>\r\n\r\n<p>\uc22b\uc790\ub294 \ub2e4\uc74c\uacfc \uac19\uc740 \uaddc\uce59\uc744 \uc9c0\ud0a4\uba74\uc11c \uc368\uc57c\ud55c\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>1\ubd80\ud130 10\uae4c\uc9c0 \uc22b\uc790\ub294 &ldquo;one&rdquo;, &ldquo;two&rdquo;, &ldquo;three&rdquo;, &ldquo;four&rdquo;, &ldquo;five&rdquo;, &ldquo;six&rdquo;, &ldquo;seven&rdquo;, &ldquo;eight&rdquo;, &ldquo;nine&rdquo;, &ldquo;ten&rdquo;\ub85c \uc4f4\ub2e4.<\/li>\r\n\t<li>11\ubd80\ud130 19\uae4c\uc9c0 \uc22b\uc790\ub294 &ldquo;eleven&rdquo;, &ldquo;twelve&rdquo;, &ldquo;thirteen&rdquo;, &ldquo;fourteen&rdquo;, &ldquo;fifteen&rdquo;, &ldquo;sixteen&rdquo;, &ldquo;seventeen&rdquo;, &ldquo;eighteen&rdquo;, &ldquo;nineteen&rdquo;\ub85c \uc4f4\ub2e4.<\/li>\r\n\t<li>\ub098\uba38\uc9c0 \ub450 \uc790\ub9ac \uc22b\uc790\ub294 \uc2ed\uc758 \uc790\ub9ac\ub97c \uc4f0\uace0 \uc77c\uc758 \uc790\ub9ac\ub97c \uc4f4\ub2e4. \ub9cc\uc57d \uc77c\uc758 \uc790\ub9ac\uac00 0\uc778 \uacbd\uc6b0\uc5d0\ub294 \uc2ed\uc758 \uc790\ub9ac\ub9cc \uc4f4\ub2e4.<\/li>\r\n\t<li>\uc2ed\uc758 \uc790\ub9ac\uc758 \uacbd\uc6b0\uc5d0 2\ubd80\ud130 9\uae4c\uc9c0\ub294 &ldquo;twenty&rdquo;, &ldquo;thirty&rdquo;, &ldquo;forty&rdquo;, &ldquo;fifty&rdquo;, &ldquo;sixty&rdquo;, &ldquo;seventy&rdquo;, &ldquo;eighty&rdquo;, &ldquo;ninety&rdquo;\ub85c \uc4f4\ub2e4.<\/li>\r\n\t<li>\uc138 \uc790\ub9ac \uc22b\uc790\ub294 \ubc31\uc758 \uc790\ub9ac\ub97c \uc4f0\uace0, \ub098\uba38\uc9c0 \ub450 \uc790\ub9ac\ub97c \uc4f4\ub2e4. \ub450 \uc790\ub9ac\uac00 0\uc778 \uacbd\uc6b0\uc5d0\ub294 \ubc31\uc758 \uc790\ub9ac\ub9cc \uc4f0\uba74 \ub41c\ub2e4.<\/li>\r\n\t<li>\ubc31\uc758 \uc790\ub9ac\uc758 \uacbd\uc6b0\uc5d0 1\ubd80\ud130 9\uae4c\uc9c0\ub294 &ldquo;onehundred&rdquo;, &ldquo;twohundred&rdquo;, &ldquo;threehundred&rdquo;, &ldquo;fourhundred&rdquo;, &ldquo;fivehundred&rdquo;, &ldquo;sixhundred&rdquo;, &ldquo;sevenhundred&rdquo;, &ldquo;eighthundred&rdquo;, &ldquo;ninehundred&rdquo;\ub85c \uc4f4\ub2e4.<\/li>\r\n\t<li>\ud56d\uc0c1 \uc138\uc790\ub9ac \uc774\ub0b4\ub85c \ubb38\uc81c\ub97c \ud480 \uc218 \uc788\ub2e4.<\/li>\r\n<\/ul>\r\n\r\n<p>\uc544\ub798\uc640 \uac19\uc774 \uc22b\uc790\ub97c \uc4f8 \uc218 \uc788\ub2e4.<\/p>\r\n\r\n<ul>\r\n\t<li>68 = &ldquo;sixty&rdquo; + &ldquo;eight&rdquo; = &ldquo;sixtyeight&rdquo;&nbsp;<\/li>\r\n\t<li>319 = &ldquo;threehundred&rdquo; + &ldquo;nineteen&rdquo; = &ldquo;threehundrednineteen&rdquo;&nbsp;<\/li>\r\n\t<li>530 = &ldquo;fivehundred&rdquo; + &ldquo;thirty&rdquo; = &ldquo;fivehundredthirty&rdquo;&nbsp;<\/li>\r\n\t<li>971 = &ldquo;ninehundred&rdquo; + &ldquo;seventy&rdquo; + &ldquo;one&rdquo; = &ldquo;ninehundredseventyone&rdquo;<\/li>\r\n<\/ul>\r\n","input":"<p>\uccab\uc9f8 \uc904\uc5d0 \ubb38\uc7a5\uc744 \uc774\ub8e8\ub294 \ub2e8\uc5b4\uc758 \uc218 N (1 &le; N &le; 20)\uac00 \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n\r\n<p>\ub2e4\uc74c N\uac1c \uc904\uc5d0\ub294 \ubb38\uc7a5\uc744 \uc774\ub8e8\ub294 \ub2e8\uc5b4\uac00 \uc8fc\uc5b4\uc9c4\ub2e4. \uc785\ub825\uc73c\ub85c \uc8fc\uc5b4\uc9c0\ub294 \ub2e8\uc5b4\ub294 \uae38\uc774\uac00 \ucd5c\ub300 50\uc774\uba70 \uc54c\ud30c\ubcb3 \uc18c\ubb38\uc790\ub85c\ub9cc \uc774\ub8e8\uc5b4\uc838 \uc788\ub2e4. \uc785\ub825\uc73c\ub85c \uc8fc\uc5b4\uc9c0\ub294 \ub2e8\uc5b4 \uc911\uc5d0 \uc22b\uc790\ub97c \ub098\ud0c0\ub0b4\ub294 \ub2e8\uc5b4\ub294 \uc5c6\ub2e4.<\/p>\r\n\r\n<p>\\$\ub294 \ud558\ub098\ub9cc \uc8fc\uc5b4\uc9c4\ub2e4.<\/p>\r\n","output":"<p>\uccab\uc9f8 \uc904\uc5d0 \ubb38\uc7a5\uc744 \ucd9c\ub825\ud55c\ub2e4. \ud56d\uc0c1 \ub2f5\uc774 \uc874\uc7ac\ud558\ub294 \uacbd\uc6b0\ub9cc \uc8fc\uc5b4\uc9c0\uba70, \uc22b\uc790\ub294 \ud56d\uc0c1 1000\ubcf4\ub2e4 \uc791\ub2e4.<\/p>\r\n","hint":"","original":"0","html_title":"0","problem_lang_tcode":"Korean"},{"problem_id":"9627","problem_lang":"1","title":"RE\u010cENICE","description":"<p>Once upon a time in a land far far away, inhabited only by math students, Iva and Vedran were discussing self-explanatory sentences. A part of these sentences is exactly one number and it is equal to the total number of letters in the sentence. Some examples are: &ldquo;This sentence has thirtyone letters.&rdquo;, &ldquo;Blah blah seventeen&rdquo;.&nbsp;<\/p>\r\n\r\n<p>Little Jurica overheard his friends&#39; conversation and decided to impress them with the amount of self-explanatory sentences he knows by heart. He rushed back home and wrote a programme which will, given a sentence, tell him the minimum number he can put inside so that the sentence is valid. Unfortunately, his computer broke and now he needs your help. Write a programme to help Jurica!&nbsp;<\/p>\r\n\r\n<p>The form of the sentence is: word1 word2 word3 &hellip; \\$ word_n-1 word_n. The character \\$ represents the place where the number should be put in.&nbsp;<\/p>\r\n\r\n<p>For example, the form of the sentence &ldquo;this sentence has thirtyone letters&rdquo; would be &ldquo;this sentence has \\$ letters&rdquo;.&nbsp;<\/p>\r\n\r\n<p>The rules that apply to writing numbers are the following:&nbsp;<\/p>\r\n\r\n<ul>\r\n\t<li>numbers from 1 to 10 are written &ldquo;one&rdquo;, &ldquo;two&rdquo;, &ldquo;three&rdquo;, &ldquo;four&rdquo;, &ldquo;five&rdquo;, &ldquo;six&rdquo;, &ldquo;seven&rdquo;, &ldquo;eight&rdquo;, &ldquo;nine&rdquo;, &ldquo;ten&rdquo;, respectively&nbsp;<\/li>\r\n\t<li>numbers from 11 to 19 are written &ldquo;eleven&rdquo;, &ldquo;twelve&rdquo;, &ldquo;thirteen&rdquo;, &ldquo;fourteen&rdquo;, &ldquo;fifteen&rdquo;, &ldquo;sixteen&rdquo;, &ldquo;seventeen&rdquo;, &ldquo;eighteen&rdquo;, &ldquo;nineteen&rdquo;&nbsp;<\/li>\r\n\t<li>the remaining double digit numbers are written in a way that we name the tens&#39; digit and add to it the name of the one digit remaining when we remove the tens&#39; digit. Specially, if by removing the tens&#39; digit we remain with zero, we add nothing to it&nbsp;<\/li>\r\n\t<li>the tens&#39; digits (respectively from 2 to 9) are named the following: &ldquo;twenty&rdquo;, &ldquo;thirty&rdquo;, &ldquo;forty&rdquo;, &ldquo;fifty&rdquo;, &ldquo;sixty&rdquo;, &ldquo;seventy&rdquo;, &ldquo;eighty&rdquo;, &ldquo;ninety&rdquo;&nbsp;<\/li>\r\n\t<li>three digit numbers are written in a way that we name the hundreds&#39; digit number and add to it the number of the double digit number remaining. Specially, if by removing the hundreds&#39; digit we remain with zero, we add nothing to it&nbsp;<\/li>\r\n\t<li>the hundreds&#39; digits (respectively from 1 to 9) are named the following: &ldquo;onehundred&rdquo;, &ldquo;twohundred&rdquo;, &ldquo;threehundred&rdquo;, &ldquo;fourhundred&rdquo;, &ldquo;fivehundred&rdquo;, &ldquo;sixhundred&rdquo;, &ldquo;sevenhundred&rdquo;, &ldquo;eighthundred&rdquo;, &ldquo;ninehundred&rdquo;&nbsp;<\/li>\r\n\t<li>the rules that apply for numbers with more than three digits are not relevant because the input data will always be such that the output is less than a thousand&nbsp;<\/li>\r\n<\/ul>\r\n\r\n<p>Examples of naming some numbers:&nbsp;<\/p>\r\n\r\n<ul>\r\n\t<li>68 = &ldquo;sixty&rdquo; + &ldquo;eight&rdquo; = &ldquo;sixtyeight&rdquo;&nbsp;<\/li>\r\n\t<li>319 = &ldquo;threehundred&rdquo; + &ldquo;nineteen&rdquo; = &ldquo;threehundrednineteen&rdquo;&nbsp;<\/li>\r\n\t<li>530 = &ldquo;fivehundred&rdquo; + &ldquo;thirty&rdquo; = &ldquo;fivehundredthirty&rdquo;&nbsp;<\/li>\r\n\t<li>971 = &ldquo;ninehundred&rdquo; + &ldquo;seventy&rdquo; + &ldquo;one&rdquo; = &ldquo;ninehundredseventyone&rdquo;&nbsp;<\/li>\r\n<\/ul>\r\n","input":"<p>The first line of input contains the integer N (1 &le; N &le; 20), the number of words in the sentence.&nbsp;<\/p>\r\n\r\n<p>Each of the following N lines contains a word not longer than 50 lowercase letters of the English alphabet or the character \\$ (none of the words will be the name of a number).&nbsp;<\/p>\r\n\r\n<p>The character \\$ will appear exactly once.&nbsp;<\/p>\r\n","output":"<p>The first and only line of output must contain the required sentence.&nbsp;<\/p>\r\n\r\n<p>The numbers are named as mentioned before, even if the sentence sounds gramatically incorrect.&nbsp;<\/p>\r\n\r\n<p>The input data will be such that a solution will always exist and is less than 1000.&nbsp;<\/p>\r\n","hint":"<p>Clarification of the second example: Sentence is split in two lines because of the lack of space in the table. The total number of letters in the sentence is 6 + 2 + 3 + 6 + 2 + 7 + 4 = 30<\/p>\r\n\r\n<p>Clarification of the third example: As you can see, this sentence is gramatically incorrect. Nevertheless, Jurica is not concerned by that, for he is a mathematician, not a linguist.<\/p>\r\n","original":"1","html_title":"0","problem_lang_tcode":"English"}]

출처

Contest > Croatian Open Competition in Informatics > COCI 2013/2014 > Contest #3 3번

  • 문제를 번역한 사람: baekjoon
  • 잘못된 데이터를 찾은 사람: jh05013