之前做过九宫格输入法的题目
搜了一下网上的解法没找到高效的解法
写一个相对高效的解法
先放上原题
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
| 假设有九宫格输入法键盘布局如下:
[ 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
|
首先直接以数字读入肯定会爆 题中给出了总长度不超过 500
一种很直接的思路是每次读一个字符,遇到空格做一个统计,然后根据统计的个数输出结果。
但既然每组输入都是相同的数字,那用字符串处理起来可能会更方便
这里放上我的算法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
| #include <iostream> #include <string> using namespace std;
const string keys[10] = { "0 ", "1,.?!","2ABC","3DEF", "4GHI","5JKL","6MNO", "7PQRS","8TUV","9WXYZ", };
int main() { string str; while (cin >> str) { // 从流中读取输入信息 string key = keys[str[0] - '0']; // 按键 int counts = (str.size() - 1) % key.size(); // 按下次数 cout << key[counts]; // 输出 } return 0; }
|
可以说是钻了题目的空子。