洛谷-P1765 手机

洛谷-P1765 手机

原题链接:https://www.luogu.com.cn/problem/P1765


题目描述

一般的手机的键盘是这样的:

img

要按出英文字母就必须要按数字键多下。例如要按出 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;
}
原文地址:https://www.cnblogs.com/yuzec/p/13384115.html