目录
  • 一、什么是恺撒密码
  • 二、程序运行环境
  • 三、恺撒密码:加密
    • 3.1 恺撒密码加密实例程序
    • 3.2 恺撒密码加密实例程序运行结果
  • 四、恺撒密码:解密
    • 4.1 恺撒密码解密实例程序
    • 4.2 恺撒密码解密实例程序运行结果
  • 五、完整程序
    • 六、总结

      一、什么是恺撒密码

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

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

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

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

      C = ( P + 3 ) mod 26

      解密方法反之,满足:

      P = ( C – 3 ) mod 26

      二、程序运行环境

      程序运行环境是:pycharm2021

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

      三、恺撒密码:加密

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

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

      3.1 恺撒密码加密实例程序

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

      # 恺撒密码加密
      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 恺撒密码加密实例程序运行结果

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

      四、恺撒密码:解密

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

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

      4.1 恺撒密码解密实例程序

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

      # 恺撒密码解密
      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 恺撒密码解密实例程序运行结果

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

      五、完整程序

      # 恺撒密码加密
      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凯撒密码的资料请关注其它相关文章!

      声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。