描述:
现在有一种密码变换算法。
九键手机键盘上的数字与字母的对应: 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