凯撒密码是古罗马凯撒大帝用来对军事情报进行加密的算法,它采用了替换方法对信息中的每一个英文字符循环替换为字母表序列该字符后面第三个字符,对应关系如下:
原文:ABCDEFGHIJKLMNOPQRSTUVWXYZ
密文:DEFGHIJKLMNOPQRSTUVWXYZABC
原文字符P,其密文字符C满足如下条件:
C=(P+3)mod26
解密方法反之,满足:
P=(C–3)mod26
chr 是 ord的互逆函数,chr(97)=a
len(x)返回字符串的长度,或者其他组合数据类型元素的个数
str(x)返回任意类型x所对应的字符串形式
chr(x)返回Unicode编码X对应的单字符
ord(x)返回单字符表示的unicode编码
hex(x)返回整数x对应十六进制的小写字符形式字符串
oct(x)返回整数x对应八进制的小写字符形式字符串
代码如下
plaincode=input("请输入明文:")
for p in plaincode:
if ord("a")<=ord(p)<=ord("z"):#ord()将字符转为ASSCLL码
print(chr(ord("a")+(ord(p)-ord("a")+3)%26),end='')
###+3是加密 -3是解密 C=(P+3)mod26 加密
###p=(c-3)mod26 解密
elif ord("A")<=ord(p)<=ord("Z"):#大写
print(chr(ord("A")+(ord(p)-ord("A")+3)%26),end='')
else:
print(p,end = '')