题目描述
一般的手机的键盘是这样的:
要按出英文字母就必须要按数字键多下。例如要按出 x 就得按 99 两下,第一下会出 w,而第二下会把 w 变成
x。00 键按一下会出一个空格。
你的任务是读取若干句只包含英文小写字母和空格的句子,求出要在手机上打出这个句子至少需要按多少下键盘。
输入格式
一行句子,只包含英文小写字母和空格,且不超过 200 个字符。
输出格式
一行一个整数,表示按键盘的总次数。
输入输出样例
输入 #1复制
i have a dream
输出 #1复制
23
说明/提示
NOI 导刊 2010 普及(10)一个暴力一个是不暴力不过不优化
#include<bits/stdc++.h>
using namespace std;
void solve(string s) {
int count = 0, num = s.size();
for (int i = 0; i < num; i++) {
if (s[i] == 's' || s[i] == 'z') {
count += 4;
} else if (s[i] == ' ') {
count++;
} else if (s[i] >= 'a' && s[i] < 's') {
count += (s[i] - 'a') % 3 + 1;
} else if (s[i] >= 't' && s[i] < 'z') {
count += (s[i] - 'a' - 1) % 3 + 1;
}
}
cout << count << "\n";
}
//i have a dream
int main() {
string s;
getline(cin, s);
solve(s);
return 0;
}
#include<bits/stdc++.h>
using namespace std;
int main() {
string s1;
getline(cin, s1);
int num = s1.size(), count = 0;
for (int i = 0; i < num; i++) {
if (s1[i] == 'a' || s1[i] == 'd' || s1[i] == 'g' || s1[i] == 'j' || s1[i] == 'm' || s1[i] == 'p' || s1[i] == 't' || s1[i] == 'w' || s1[i] == ' ') {
count += 1;
}
if (s1[i] == 'b' || s1[i] == 'e' || s1[i] == 'h' || s1[i] == 'k' || s1[i] == 'n' || s1[i] == 'q' || s1[i] == 'u' || s1[i] == 'x') {
count += 2;
}
if (s1[i] == 'c' || s1[i] == 'f' || s1[i] == 'i' || s1[i] == 'l' || s1[i] == 'o' || s1[i] == 'r' || s1[i] == 'v' || s1[i] == 'y') {
count += 3;
}
if (s1[i] == 's' || s1[i] == 'z') {
count += 4;
}
}
cout << count << "\n";
return 0;
}