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;
}