【PTA 7-9】九宫格输入法
7-9 九宫格输入法 (15 分)
假设有九宫格输入法键盘布局如下:
[ 1,.?! ] [ 2ABC ] [ 3DEF ]
[ 4GHI ] [ 5JKL ] [ 6MNO ]
[ 7PQRS ] [ 8TUV ] [ 9WXYZ ]
[ 0空 ]
注意:中括号[ ]
仅为了表示键盘的分隔,不是输入字符。每个中括号中,位于首位的数字字符即是键盘的按键,按一下即可输入该数字字符。多次按同一个键,则输入的字符依次循环轮流,例如按两次3
,则输入D
;按5次7
,则输入S
;按6次2
,则输入A
。按键0
的输入组合是0
和空格
字符,即按两次0
输入空格。
你需要对于给定的按键组合,给出该组合对应的文本。
输入格式:
输入在一行中给出数个字符的按键组合(例如 999
表示按3次9
),每个字符的按键组合之间用空格间隔,最后一个输入法组合之后以换行结束。输入数据至少包括一个字符的按键组合,且输入总长度不超过500个字符。
输出格式:
在一行中输出该按键组合对应的文本。
输入样例:
22 5555 22 666 00 88 888 7777 4444 666 44
输出样例:
ALAN TURING
要处理好取模问题
代码:
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 0x3f3f3f3f
#define mem(a,b) memset(a,b,sizeof(a))
int main()
{
int i;
string a[15],s;
a[1]="1,.?!";
a[2]="2ABC";
a[3]="3DEF";
a[4]="4GHI";
a[5]="5JKL";
a[6]="6MNO";
a[7]="7PQRS";
a[8]="8TUV";
a[9]="9WXYZ";
a[0]="0 ";
getline(cin,s);
s+=' ';
int t=0,num=0;
for(i=0;i<s.length();i++)
{
if(s[i]==' ')
{
//cout<<t<<" "<<num<<endl;
if(num%a[t].length()==0)
num=a[t].length();
else if(num>a[t].length())
num%=a[t].length();
cout<<a[t][num-1];
t=0;
num=0;
continue;
}
t=s[i]-'0';
num++;
}
return 0;
}