描述:
现在有一种密码变换算法。
九键手机键盘上的数字与字母的对应: 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≤n≤100
输入描述:输入一组密码,长度不超过100个字符。
输出描述:输出密码变换后的字符串
示例1
输入:YUANzhi1987
输出:zvbo9441987
while True:
try:
InputStr = input()
if 1 <= len(InputStr) <= 100:
OutputStr = "" # 利用字符通过 + 进行连接
for x in InputStr:
if x.islower(): # 如果是小写字母,按对应关系进行转换即可
if x in "abc":
OutputStr = OutputStr + '2'
elif x in "def":
OutputStr = OutputStr + '3'
elif x in "ghi":
OutputStr = OutputStr + '4'
elif x in "jkl":
OutputStr = OutputStr + '5'
elif x in "mno":
OutputStr = OutputStr + '6'
elif x in "pqrs":
OutputStr = OutputStr + '7'
elif x in "tuv":
OutputStr = OutputStr + '8'
elif x in "wxyz":
OutputStr = OutputStr + '9'
elif x.isupper(): # 如果是大写字母,要先转换成小写字母,再后移以为;特别关注是z后移一位是z
if x == "Z":
OutputStr = OutputStr + chr(ord(x) + 7) # ASSIC码,A是65,Z是65+25=90,a是97,z是97+25=122
else:
OutputStr = OutputStr + chr(ord(x.lower()) + 1) # 只要非大写Z,就可以先转换小写,再加1,再转换成字母
else: # 数字和其他字符,不做任何处理
OutputStr = OutputStr + str(x)
print(OutputStr)
except:
break