一文详解凯撒密码的原理及Python实现

08-22 165阅读 0评论

一、什么是恺撒密码

恺撒密码是古罗马恺撒大帝用来对军事情报进行加密的算法,它采用了替换方法对信息中的每一个英文字符循环替换为字母表序列该字符后面第三个字符:

原文:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

密文:D E F G H I J K L M N O P Q R S T U V W X Y Z A B C

原文字符P,其密文字符C满足如下条件:

C = ( P + 3 ) mod 26

解密方法反之,满足:

P = ( C – 3 ) mod 26

二、程序运行环境

程序运行环境是:pycharm2021

三、恺撒密码:加密

恺撒密码的加密算法程序首先接收用户输入的文本

然后对字母a-z和字母A-Z按照密码算法进行转换

3.1 恺撒密码加密实例程序

# 恺撒密码加密 def Caesar_PW_EncryptiON(): inputText = input("请输入明文文本: ") for index in inputText: if "a" <= index <= "z": print(chr(ord("a") + (ord(index) - ord("a") + 3) % 26), end='') elif "A" <= index <= "Z": print(chr(ord("A") + (ord(index) - ord("A") + 3) % 26), end='') else: print(index, end='') 

在主函数调用这个Caesar_PW_Encryption恺撒密码加密函数,如下所示

if __name__ == '__main__': # 恺撒密码加密 Caesar_PW_Encryption() 

3.2 恺撒密码加密实例程序运行结果

四、恺撒密码:解密

恺撒密码的解密算法程序首先接收用户输入的加密文本

然后对字母a-z和字 母A-Z按照密 码算法进行反向转换

4.1 恺撒密码解密实例程序

# 恺撒密码解密 def Ceasar_PW_Decryption(): inputText = input("请输入加密后文本: ") for index in inputText: if "a" <= index <= "z": print(chr(ord("a") + (ord(index) - ord("a") - 3) % 26), end='') elif "A" <= index <= "Z": print(chr(ord("A") + (ord(index) - ord("A") - 3) % 26), end='') else: print(index, end='')

在主函数中调用这个Caesar_PW_Encryption恺撒密码加密函数,如下所示

if __name__ == '__main__': # 恺撒密码加密 Caesar_PW_Encryption()  # 恺撒密码解密 Ceasar_PW_Decryption()  

4.2 恺撒密码解密实例程序运行结果

五、完整程序

# 恺撒密码加密 def Caesar_PW_Encryption(): inputText = input("请输入明文文本: ") for index in inputText: if "a" <= index <= "z": print(chr(ord("a") + (ord(index) - ord("a") + 3) % 26), end='') elif "A" <= index <= "Z": print(chr(ord("A") + (ord(index) - ord("A") + 3) % 26), end='') else: print(index, end='')  # 恺撒密码解密 def Ceasar_PW_Decryption(): inputText = input("请输入加密后文本: ") for index in inputText: if "a" <= index <= "z": print(chr(ord("a") + (ord(index) - ord("a") - 3) % 26), end='') elif "A" <= index <= "Z": print(chr(ord("A") + (ord(index) - ord("A") - 3) % 26), end='') else: print(index, end='')  if __name__ == '__main__': # 恺撒密码加密 Caesar_PW_Encryption()  # 恺撒密码解密 Ceasar_PW_Decryption()

六、总结

本文主要讲解了恺撒密码:采用了替换方法对信息中的每一个英文字符循环替换为字母表序列该字符后面第三个字符。并通过一个实例程序来进一步加强对恺撒密码的理解与运用。

以上就是一文详解凯撒密码的原理Python实现的详细内容,更多关于python凯撒密码的资料请关注云初冀北其它相关文章!

免责声明
本站提供的资源,都来自网络,版权争议与本站无关,所有内容及软件的文章仅限用于学习和研究目的。不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负,我们不保证内容的长久可用性,通过使用本站内容随之而来的风险与本站无关,您必须在下载后的24个小时之内,从您的电脑/手机中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。侵删请致信E-mail:Goliszhou@gmail.com
$

发表评论

表情:
评论列表 (暂无评论,165人围观)

还没有评论,来说两句吧...