(File IO): input:mobile.in output:mobile.out
时间限制: 1000 ms 空间限制: 128000 KB 具体限制
Goto ProblemSet
题目描述
一般的手机的键盘是这样的:
要按出英文字母就必须要按数字键多下。例如要按出
x
x
x 就得按
9
9
9 两下,第一下会出
w
w
w,而第二下会把
w
w
w 变成
x
x
x。
0
0
0 键按一下会出一个空格。
你的任务是读取若干句只包含英文小写字母和空格的句子,求出要在手机上打出这个句子至少需要按多少下键盘。
输入
输入文件只包含一行,表示一个句子,句子中只包含英文小写字母和空格,且不超过
200
200
200 个字符。
输出
一行一个整数,表示按键盘的总次数。
样例输入
i have a dream
样例输出
23
数据范围限制
不超过
200
200
200 个字符。
解题思路
先把每个字母的点击次数打表出来,然后注意一些关于字符串的运用,纯模拟就行。。
代码
#include<bits/stdc++.h>
using namespace std;
int a[50]={1,2,3,1,2,3,1,2,3,1,2,3,1,2,3,1,2,3,4,1,2,3,1,2,3,4},ans,l;
string s;
int main()
{
freopen("mobile.in","r",stdin);
freopen("mobile.out","w",stdout);
getline(cin,s);
int l=s.size();
for(int i=0;i<l;i++)
{
if(s[i]==' ') ans++;
if(s[i]>='a'&&s[i]<='z') ans+=a[s[i]-'a'];
}
printf("%d\n",ans);
return 0;
}