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