描述
对输入的字符串进行加解密,并输出。
加密方法为:
当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,如字母a时则替换为B;字母Z时则替换为a;
当内容是数字时则把该数字加1,如0替换1,1替换2,9替换0;
其他字符不做变化。
解密方法为加密的逆过程。
数据范围:输入的两个字符串长度满足 1 \le n \le 1000 \1≤n≤1000 ,保证输入的字符串都是只由大小写字母或者数字组成
输入描述:
第一行输入一串要加密的密码
第二行输入一串加过密的密码
输出描述:
第一行输出加密后的字符
第二行输出解密后的字符
思路:
纯模拟,使用ord函数获得ASCII码,使用chr函数将ASCII码转换为字符。需要注意的是,加密和解密的过程中ASCII码取余来实现z和a的衔接,其中的一些细节
a=list(input()) b=list(input()) #加密 for i in range(len(a)): if a[i].isalpha(): if "a"<=a[i]<="z": #先+1再减字母a的ASCII,此时的结果有可能超过z,通过模26再绕回来,最后得到是字母表的第几个之后再加回a a[i]=chr((ord(a[i])+1-ord("a"))%26+ord("a")) a[i]=a[i].upper() else: a[i]=chr((ord(a[i])+1-ord("A"))%26+ord("A")) a[i]=a[i].lower() else: a[i]=chr((ord(a[i])+1-ord("0"))%10+ord("0")) #解密 for i in range(len(b)): if b[i].isalpha(): if "a"<=b[i]<="z": #这里跟加密不一样的是,-1之后有可能结果比a小,那么就通过+26再模26的方法绕回来, #实际上在模运算系统里面【-1】和【+25】是同样的操作 b[i]=chr((ord(b[i])-1-ord("a")+26)%26+ord("a")) b[i]=b[i].upper() else: b[i]=chr((ord(b[i])-1-ord("A")+26)%26+ord("A")) b[i]=b[i].lower() else: b[i]=chr((ord(b[i])-1-ord("0")+10)%10+ord("0")) a1="".join(a) b1="".join(b) print(a1) print(b1)