目录
描述
现在有一种密码变换算法。
九键手机键盘上的数字与字母的对应: 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个字符。
输出描述:
输出密码变换后的字符串
做题过程
离谱,忘了边界了。
我的代码
#include <stdio.h>
#include <string.h>
int main() {
int a, b;
char arr[100];
scanf("%s",&arr[0]);
int len=strlen(arr);
for(a=0;a<len;a++)
{
if(arr[a]>=65&&arr[a]<90)//如果是大写字母作为输入,那么输出小写字母加1.不包含Z
{
arr[a]+=33;printf("%c",arr[a]);
}
else {
switch(arr[a])//输入的是Z或者小写字母
{
case 'Z':arr[a]='a';break;//这里要注意,不能忘记边界了
case 'a':case 'b':case 'c':arr[a]='2';break;
case 'd':case 'e':case 'f':arr[a]='3';break;
case 'g':case 'h':case 'i':arr[a]='4';break;
case 'j':case 'k':case 'l':arr[a]='5';break;
case 'm':case 'n':case 'o':arr[a]='6';break;
case 'p':case 'q':case 'r':case 's':arr[a]='7';break;
case 't':case 'u':case 'v':arr[a]='8';break;
case 'w':case 'x':case 'y':case 'z':arr[a]='9';break;
}
printf("%c",arr[a]);
}
}
return 0;
}
学习优秀代码
来源https://blog.nowcoder.net/n/f0bababad34844699d5c6d88fde223b5
const string dict1="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";//输入数据集
const string dict2="bcdefghijklmnopqrstuvwxyza22233344455566677778889999";//输出数据集
char Char_Change(char a){
/*一旦有输入,就在输入数据集中查找,一旦可以查找到,就将输出数据集重对应位置的数据进行输出*/
for(int i=0;i<dict1.size();i++)
if(dict1[i]==a) return dict2[i];
return a;
}