#P8243. [COCI 2013/2014 #3] REČENICE
[COCI 2013/2014 #3] REČENICE
题目描述
很久以前,在一个只有数学学生居住的遥远国度里,Iva 和 Vedran 正在讨论一种特殊的句子。这些句子中正好有一个单词表示一个数字,并且这个数字等于句子中字母的总数。例如 This sentence has thirtyone letters. 和 Blah Blah seventeen。
Jurica 无意中听到了朋友们的谈话,决定用他背诵的大量特殊的句子给他们留下深刻印象。他急忙回家,写了一个程序,给定一个句子,求出使得句子变得特殊的能放进去的最小数字。
不幸的是,他的电脑坏了,现在他需要你的帮助。写一个程序来帮助 Jurica!
以下是一些补充说明:
- 句子的形式是:$\textit{word}_1~\textit{word}_2~\textit{word}_3~\cdots~\textit{word}_{n-1}~\textit{word}_n$。这 个单词中恰好有一个
$,表示需要填入的表示一个数字的单词。例如,this sentence has thirtyone letters将变为this sentence has $ letters。 - 用来表示数字的单词遵循如下规则:
- 对于所有 的整数,表示它们的单词从小到大依次为
one、two、three、four、five、six、seven、eight、nine、ten、eleven、twelve、thirteen、fourteen、fifteen、sixteen、seventeen、eighteen和nineteen。 - 对于所有 的整十数,表示它们的单词从小到大依次为
twenty、thirty、forty、fifty、sixty、seventy、eighty、ninety。 - 对于所有 的整百数,表示它们的单词从小到大依次为
onehundred、twohundred、threehundred、fourhundred、fivehundred、sixhundred、sevenhundred、eighthundred、ninehundred。 - 对于其它所有的两位数,先在开头放入表示不超过该数的最大的整十数的单词,再在后面拼接表示该两位数的个位数的单词。例如,表示整数 的单词为
sixtyeight。 - 对于其它所有的三位数,先在开头放入表示不超过该数的最大的整百数的单词,再在后面拼接表示其后两位数的单词(按照前面的规则)。例如,表示整数 的单词分别为
threehundrednineteen、fivehundredthirty和ninehundredseventyone。
- 对于所有 的整数,表示它们的单词从小到大依次为
输入格式
第一行输入一个整数 ,表示句子中的单词个数。
随后 行,每行一个字符串,表示句子中的所有单词。保证 $ 在其中恰好出现一次。
输出格式
输出一行 个字符串,表示将 $ 替换为使得句子特殊的表示最小数字的单词后的句子。
5
this
sentence
has
$
letters
this sentence has thirtyone letters
7
$
is
the
number
of
letters
here
thirty is the number of letters here
5
the
letters
are
$
potato
the letters are twentynine potato
提示
【样例 2 解释】
$ 填入表示整数 的单词 thirty,此时所有单词的字母总数为 。
【样例 3 解释】
请注意本题中的句子可能并不满足英语语法要求。
【数据范围与限制】
本题开启捆绑测试。各个子任务的分值和特殊限制如下所述:
- Subtask 1(40 pts):
$中填入的单词所对应的数字不超过 。 - Subtask 2(60 pts):无特殊限制。
对于所有数据,,$ 中填入的单词所对应的数字不超过 。
【题目来源】
本题来源自 COCI 2013-2014 CONTEST 3 T3 REČENICE,按照原题数据配置,满分 分。
由 Eason_AC 翻译整理提供。