原题解答
本次的题目如下所示(原题出处:NOC)
一般的手机的键盘是这样的:
要按出英文字母就必须要按数字键多下。例如要按出 x 就得按 9 两下,第一下会出 w,而第二下会把 w 变成 x。0 键按一下会出一个空格。
你的任务是读取若干句只包含英文小写字母和空格的句子,求出要在手机上打出这个句子至少需要按多少下键盘。
输入格式
一行句子,只包含英文小写字母和空格,且不超过 200 个字符。
输出格式
一行一个整数,表示按键盘的总次数。
输入样例
i have a dream
输出 样例
23
本道题本身并不是很难,而且解题的方法也有多种,关键在于能不能读懂题目,有没有思路。这总键盘对于现在的孩子来说相对较为陌生,是诺基亚时代的手机输入方式。
我们先解释一下如何通过“i have a dream”得到23这个结果的。键盘上2到9折八个数字每个数字各对应3到4个字母,如果我们要键入第一个字母,只要按一下对应的数字键;键入第二个字母则要连续按两下这个数字键。也就是键入一个字母最多可能要按4下,比如字母s和字母z。以下是这句话中各个字母需要按键盘的次数:
i |