洛谷-P1765 手机
洛谷-P1765 手机
题目描述
一般的手机的键盘是这样的:
要按出英文字母就必须要按数字键多下。例如要按出 x
就得按 9 两下,第一下会出 w
,而第二下会把 w
变成 x
。0 键按一下会出一个空格。
你的任务是读取若干句只包含英文小写字母和空格的句子,求出要在手机上打出这个句子至少需要按多少下键盘。
输入格式
一行句子,只包含英文小写字母和空格,且不超过 200 个字符。
输出格式
一行一个整数,表示按键盘的总次数。
输入输出样例
输入 #1
i have a dream
输出 #1
23
说明/提示
NOI导刊2010普及(10)
C++代码
#include <iostream>
#include <cstring>
#include <map>
using namespace std;
int main() {
int j=0, ans=0;
string s;
getline(cin, s);
map<char, int> m;
m[' '] = 1;
for (char i='a'; i<='z'; ++i, ++j) {
if (i != 's' && i != 'z') {
j %= 3;
m[i] = j + 1;
} else {
m[i] = j + 1;
j = -1;
}
}
for (int i=0; i<s.size(); ++i)
ans += m[s[i]];
cout << ans << endl;
return 0;
}