描述
现在有一种密码变换算法。
九键手机键盘上的数字与字母的对应: 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 。
数字和其它的符号都不做变换。
数据范围: 输入的字符串长度满足
输入描述:
输入一组密码,长度不超过100个字符。
输出描述:
输出密码变换后的字符串
思路:
step1:输入明文n,创建字典dic(“A-Z”对应的“b-a”),创建“shuzi”字符串(“0-9”),创建空串x(便于输出密文)
step2:遍历明文n,如果i在“shuzi”内,则直接将数字加到x中;如果i在字典内,则将对应的字母加到x中;如果i是小写字母,则按照题目要求,将对应的数字字符加到x中;
step3:打印密文x
代码如下:
while True:
try:
n = input()
dic={'A':'b','B':'c','C':'d','D':'e','E':'f','F':'g','G':'h','H':'i','I':'j','J':'k','K':'l','L':'m','M':'n','N':'o','O':'p','P':'q','Q':'r','R':'s','S':'t','T':'u','U':'v','V':'w','W':'x','X':'y','Y':'z','Z':'a'}
shuzi = '0123456789'
x = ''
for i in n:
if i in shuzi:
x += i
elif i in dic:
x += dic[i]
else:
if i in 'abc':
x += '2'
elif i in 'def':
x += '3'
elif i in 'ghi':
x += '4'
elif i in 'jkl':
x += '5'
elif i in 'mno':
x += '6'
elif i in 'pqrs':
x += '7'
elif i in 'tuv':
x += '8'
elif i in 'wxyz':
x += '9'
print(x)
except:
break