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

原文字符与其密文字符满足如下条件:

密 = (原+3) mod 26

解密方法反之,满足:

原 = (密--3) mod 26

请解密:HAFHOOHQW

输出样例如下:

python 复制代码
encrypted_text = "HAFHOOHQW"
print(f"待解密码为:{encrypted_text}")
decrypted_text = ""
for char in encrypted_text:
    if char.isalpha():
        if char.isupper():
            original_char = chr((ord(char) - ord('A') - 3) % 26 + ord('A'))
        else:
            original_char = chr((ord(char) - ord('a') - 3) % 26 + ord('a'))
        decrypted_text += original_char
    else:
        decrypted_text += char

print(f"解得密码为:{decrypted_text}")

这段 Python 代码的主要功能是对一个经过简单凯撒密码加密的文本进行解密操作。凯撒密码是一种简单的替换加密方法,它将字母表中的每个字母按照固定的位数进行位移。在这段代码中,加密时字母向右移动了 3 位,因此解密时需要将字母向左移动 3 位。下面是对代码的详细解释:

1. 定义加密文本 :将加密后的文本 "HAFHOOHQW" 赋值给变量 encrypted_text,并打印待解密码的信息。

2. 初始化解密文本 :创建一个空字符串 decrypted_text,用于存储解密后的文本。

3. 遍历加密文本 :使用 for 循环遍历 encrypted_text 中的每个字符。

4. 字符处理

  • 如果字符是字母,则根据其大小写进行不同的处理:
  • 对于大写字母,将其向左移动 3 位,通过计算偏移量并转换为对应的字符。
  • 对于小写字母,同样将其向左移动 3 位。
  • 如果字符不是字母,则直接将其添加到解密文本中。

5. 打印解密结果 :将解密后的文本存储在 decrypted_text 中,并打印解得密码的信息。

觉得有帮助就给博主点个关注叭~~

有问题的可以私信或者在评论区一起交流

友友们一起加油叭QAQ

相关推荐
sprite_雪碧2 分钟前
枚举 / 搜索类算法(机试核心考点)
算法
telllong4 分钟前
消息总线设计:asyncio.Queue实战
python·架构设计·asyncio
罗湖老棍子8 分钟前
简单题(信息学奥赛一本通- P1539)
数据结构·算法·树状数组·区间修改 单点查询
羊小猪~~15 分钟前
【论文精度】Transformer---大模型基石
人工智能·深度学习·考研·算法·机器学习·transformer
西西弟27 分钟前
常见排序算法集合(数据结构)
数据结构·算法·排序算法
伏 念29 分钟前
大模型技术之LLM
人工智能·笔记·python·aigc
Yzzz-F32 分钟前
[模板]Nim博弈
算法
小龙报33 分钟前
【数据结构与算法】栈和队列的综合应用:1.用栈实现队列 2.用队列实现栈 3.设计循环队列
c语言·数据结构·数据库·c++·redis·算法·缓存
dapeng287037 分钟前
使用Fabric自动化你的部署流程
jvm·数据库·python
重生之我是Java开发战士39 分钟前
【广度优先搜索】队列:N叉树的层序遍历,二叉树的锯齿形层序遍历,二叉树的最大宽度,在每个树行中找最大值
数据结构·算法·leetcode·广度优先