1.凯撒密码的加密: plaincode=input("请输入明文:")#输入的明文 for i in plaincode: if ord("a") <= ord(i) <= ord("z"):#当i为小写字母的范围时 print(chr(ord("a")+(ord(i)-ord("a")+3)%26))#此时需要注意溢出的情况,我们需要用周期来解决这个问题"(ord(i)-ord("a")+3)"这一串代码主要是表示加密转换之后的字母所对应的序号,由于这个序号可能超过26个小写字母的表示范围,所以我们需要除以它的周期,就得出了正常的序号,正常的序号加上“a”字母unicode编码,就得出了暗文的字母。 elif ord("A") <= ord(i) <= ord("Z"):#同上 print(chr(ord("A")+(ord(i)-ord("A")+3)%26)) else: print(i)#如果是非字母就直接输出了 2.凯撒密码的解密: blackcodes=input("请输入暗码:")#输入暗文 for i in blackcodes: if ord("a") <= ord(i) <= ord("z"):#当i为小写字母的范围时 print(chr(ord("a")+(ord(i)-ord("a")-3+26)%26),end="")#此时需要注意序号为负数和溢出这两种特殊的情况,首先解决序号为负的情况,"(ord(i)-ord("a")-3+26)"序号加上一个周期,这就解决了序号为负的情况,再者我们需要解决溢出的情况,将我们上面所得的序列除于周期26就得出了正常的序号了,之后再将我们的正常序号加上“a”字母unicode编码,就得出了明文的字母 elif ord("A") <= ord(i) <= ord("Z"): print(chr(ord("A")+(ord(i)-ord("A")-3+26)%26),end="")#同上 else: print(i,end="")