1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > Python基础编程入门实例:恺撒密码

Python基础编程入门实例:恺撒密码

时间:2022-05-18 05:49:29

相关推荐

Python基础编程入门实例:恺撒密码

文章目录

Python基础编程入门实例:恺撒密码一、什么是恺撒密码二、程序运行环境三、恺撒密码:加密3.1、恺撒密码加密实例程序3.2、恺撒密码加密实例程序运行结果四、恺撒密码:解密4.1、恺撒密码解密实例程序4.2、恺撒密码解密实例程序运行结果五、完整程序六、总结

Python基础编程入门实例:恺撒密码

一、什么是恺撒密码

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

原文: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

二、程序运行环境

程序运行环境是:pycharm

三、恺撒密码:加密

恺撒密码的加密算法程序首先接收用户输入的文本然后对字母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()

六、总结

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。