描述
现在有一种密码变换算法。
九键手机键盘上的数字与字母的对应: 1--1, abc--2, def--3, ghi--4, jkl--5, mno--6, pqrs--7, tuv--8 wxyz--9, 0--0,把密码中出现的小写字母都变成九键键盘对应的数字,如:a 变成 2,x 变成 9.
而密码中出现的大写字母则变成小写之后往后移一位,如:X ,先变成小写,再往后移一位,变成了 y ,例外:Z 往后移是 a 。
数字和其它的符号都不做变换。
数据范围: 输入的字符串长度满足 1 \le n \le 100 \1≤n≤100
输入描述:
输入一组密码,长度不超过100个字符。
输出描述:
输出密码变换后的字符串
示例
输入:YUANzhi1987
输出:zvbo9441987
代码
#include <iostream>
#include <string>
using namespace std;
void encode(string input, string& output) {
output = input;
for (int i = 0; i < output.size(); i++) {
if (output[i] == 'a' || output[i] == 'b' || output[i] == 'c') {
output[i] = '2';
} else if (output[i] == 'd' || output[i] == 'e' || output[i] == 'f') {
output[i] = '3';
} else if (output[i] == 'g' || output[i] == 'h' || output[i] == 'i') {
output[i] = '4';
} else if (output[i] == 'j' || output[i] == 'k' || output[i] == 'l') {
output[i] = '5';
} else if (output[i] == 'm' || output[i] == 'n' || output[i] == 'o') {
output[i] = '6';
} else if (output[i] == 'p' || output[i] == 'q' || output[i] == 'r' ||
output[i] == 's') {
output[i] = '7';
} else if (output[i] == 't' || output[i] == 'u' || output[i] == 'v') {
output[i] = '8';
} else if (output[i] == 'w' || output[i] == 'x' || output[i] == 'y' ||
output[i] == 'z') {
output[i] = '9';
} else if (output[i] >= 'A' && output[i] < 'Z') {
output[i] = output[i] + 33;
} else if (output[i] == 'Z') {
output[i] = 'a';
}
}
}
int main() {
string a, b;
cin >> a;//输入字符串
encode(a, b);//编码
cout << b << endl;//输出编码字符串
return 0;
}
结果