编写一个生成凯撒密码的程序

plain = list(input("请输入需要加密的明文(只支持英文字母):"))

key = int(input("请输入移动的位数:"))

    

base_A = ord('A')

base_a = ord('a')

    

cipher = []

for each in plain:

    if each == ' ':

        cipher.append(' ')

    else:

        if each.isupper():

            base = base_A

        else:

            base = base_a

        cipher.append(chr((ord(each) - base + key) % 26 + base))

    

print(''.join(cipher))

 

plain = list(input("请输入需要加密的明文(只支持英文字母):"))

key = int(input("请输入移动的位数:"))

   

base_A = ord('A')

base_a = ord('a')

   

cipher = []

for each in plain:

    if each == ' ':

        cipher.append(' ')

    else:

        if each.isupper():

            base = base_A

        else:

            base = base_a

        cipher.append(chr((ord(each) - base + key) % 26 + base))

   

print(''.join(cipher))


【对关键步骤详细的解析】

在第7步之后的逻辑主要处理的是如何通过凯撒加密对字母进行位移,并且确保字母仍然保持在字母表内(即 'A'-'Z' 或 'a'-'z' 之间)。这部分的逻辑相对关键,涉及到字符的转换和加密。

### 第7步及之后的代码:

```python
else:
    if each.isupper():
        base = base_A
```

- 如果字符不是空格,首先判断它是大写字母还是小写字母。通过 `each.isupper()` 判断。
  - 如果是大写字母(如 'A', 'B', 'C' 等),`base` 被设置为 `base_A`,即 `'A'` 的 ASCII 值(65)。
  - 如果是小写字母,`base` 被设置为 `base_a`,即 `'a'` 的 ASCII 值(97)。

```python
else:
    base = base_a
```

- 如果是小写字母(如 'a', 'b', 'c' 等),则 `base` 被设置为小写字母 'a' 的 ASCII 值。

### 8. 字母加密的核心代码:

```python
cipher.append(chr((ord(each) - base + key) % 26 + base))
```

这行代码执行了加密操作。下面分步解释它的功能:

1. **获取当前字母的 ASCII 值:**  
   `ord(each)` 取出当前字符 `each` 的 ASCII 值。假设 `each = 'A'`,那么 `ord('A') = 65`。

2. **计算相对于字母表起始的偏移量:**  
   `ord(each) - base` 计算当前字母相对于字母表起始位置('A' 或 'a')的偏移量。假设当前字符是 `'A'`(并且 `base = base_A = 65`),则:
   - `ord('A') - 65 = 0`(因为 'A' 在字母表中的位置是 0)。
   
   如果当前字符是 `'B'`,则:
   - `ord('B') - 65 = 1`,表示 'B' 在字母表中的位置是 1。

3. **进行位移并确保结果在字母表范围内:**  
   `(ord(each) - base + key) % 26` 这一部分对计算得到的偏移量进行加密。加上 `key` 后,通过 `% 26` 保证偏移量不会超出 0 到 25 的范围。这里的 `26` 是字母表的长度(26 个字母)。

   - 比如 `key = 3`,并且当前字母是 `'A'`,那么:
     - 偏移量 `ord('A') - 65 = 0`
     - `(0 + 3) % 26 = 3`,结果是 3,表示字母表中的第 3 个字母('D')。

4. **将偏移后的结果转换回字母:**  
   `chr(... + base)` 将计算得到的新偏移量转回字母,并加上基准值 `base`。这个 `base` 是对应大写字母或小写字母的起始 ASCII 值,确保加密后的字母仍然在正确的字母表范围内。

   - 比如,如果计算的结果是 3(对于大写字母 'A'),那么 `chr(3 + 65) = 'D'`,即加密后的字符是 `'D'`。
   - 如果当前字母是 `'a'`,且 `key = 3`,计算过程类似,结果是 `'d'`。

### 示例说明:

#### 例子 1:大写字母加密

- 明文:`A B C D`
- 偏移量:`key = 3`

按照加密过程,我们逐个字符进行加密:

- 对于 `'A'`:
  1. `ord('A') = 65`
  2. `65 - 65 = 0`(偏移量)
  3. `(0 + 3) % 26 = 3`
  4. `chr(3 + 65) = 'D'`
  5. 所以 `'A'` 被加密为 `'D'`。

- 对于 `'B'`:
  1. `ord('B') = 66`
  2. `66 - 65 = 1`(偏移量)
  3. `(1 + 3) % 26 = 4`
  4. `chr(4 + 65) = 'E'`
  5. 所以 `'B'` 被加密为 `'E'`。

- 对于 `'C'`:
  1. `ord('C') = 67`
  2. `67 - 65 = 2`(偏移量)
  3. `(2 + 3) % 26 = 5`
  4. `chr(5 + 65) = 'F'`
  5. 所以 `'C'` 被加密为 `'F'`。

- 对于 `'D'`:
  1. `ord('D') = 68`
  2. `68 - 65 = 3`(偏移量)
  3. `(3 + 3) % 26 = 6`
  4. `chr(6 + 65) = 'G'`
  5. 所以 `'D'` 被加密为 `'G'`。

最终,加密后的密文是:`D E F G`

#### 例子 2:小写字母加密

- 明文:`a b c d`
- 偏移量:`key = 2`

逐个字符加密:

- 对于 `'a'`:
  1. `ord('a') = 97`
  2. `97 - 97 = 0`(偏移量)
  3. `(0 + 2) % 26 = 2`
  4. `chr(2 + 97) = 'c'`
  5. 所以 `'a'` 被加密为 `'c'`。

- 对于 `'b'`:
  1. `ord('b') = 98`
  2. `98 - 97 = 1`(偏移量)
  3. `(1 + 2) % 26 = 3`
  4. `chr(3 + 97) = 'd'`
  5. 所以 `'b'` 被加密为 `'d'`。

- 对于 `'c'`:
  1. `ord('c') = 99`
  2. `99 - 97 = 2`(偏移量)
  3. `(2 + 2) % 26 = 4`
  4. `chr(4 + 97) = 'e'`
  5. 所以 `'c'` 被加密为 `'e'`。

- 对于 `'d'`:
  1. `ord('d') = 100`
  2. `100 - 97 = 3`(偏移量)
  3. `(3 + 2) % 26 = 5`
  4. `chr(5 + 97) = 'f'`
  5. 所以 `'d'` 被加密为 `'f'`。

最终,加密后的密文是:`c d e f`

### 总结

1. **偏移量计算:** 每个字母的偏移量通过 `ord(each) - base` 计算,得到相对字母表的偏移。
2. **加密过程:** 通过 `(ord(each) - base + key) % 26` 保证加密后的字母仍然在字母表范围内。
3. **转换为字符:** 计算出新的偏移量后,再通过 `chr(... + base)` 将其转换为加密后的字符。

这种方法确保了大写字母和小写字母分别独立加密,同时保证字母表的循环性(例如 'Z' 加密后是 'A','z' 加密后是 'a')。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/918185.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

k8s上部署redis高可用集群

介绍: Redis Cluster通过分片(sharding)来实现数据的分布式存储,每个master节点都负责一部分数据槽(slot)。 当一个master节点出现故障时,Redis Cluster能够自动将故障节点的数据槽转移到其他健…

【工具插件类教学】在 Unity 中使用 iTextSharp 实现 PDF 文件生成与导出

目录 一、准备工作 1. 安装 iTextSharp 2. 准备资源文件 二、创建 ExportPDFTool 脚本 1、初始化 PDF 文件,设置字体 2、添加标题、内容、表格和图片 三、使用工具类生成 PDF 四、源码地址 在 Unity 项目中,我们有时会需要生成带有文本、表格和图片的 PDF 文件,以便…

Centos 7 安装wget

Centos 7 安装wget 最小化安装Centos 7 的话需要上传wget rpm包之后再路径下安装一下。rpm包下载地址(http://mirrors.163.com/centos/7/os/x86_64/Packages/) 1、使用X-ftp 或者WinSCP等可以连接上传的软件都可以首先连接服务器,这里我用的…

任意文件下载漏洞

1.漏洞简介 任意文件下载漏洞是指攻击者能够通过操控请求参数,下载服务器上未经授权的文件。 攻击者可以利用该漏洞访问敏感文件,如配置文件、日志文件等,甚至可以下载包含恶意代码的文件。 这里再导入一个基础: 你要在网站下…

PySpark——Python与大数据

一、Spark 与 PySpark Apache Spark 是用于大规模数据( large-scala data )处理的统一( unified )分析引擎。简单来说, Spark 是一款分布式的计算框架,用于调度成百上千的服务器集群,计算 TB 、…

推荐一款流程图和图表绘制工具:WizFlow Flowcharter Pro

WizFlow Flowcharter是一款易于使用、功能丰富的Windows流程图和图表绘制工具。它允许用户使用超过一百种预定义的形状和箭头定义形状“样式”。您可以将自己的样式保存在图表模板中,以建立自己的绘图方法。WizFlow附带了完整的流程图模板,以帮助您入门。…

关系型数据库和非关系型数据库详解

文章目录 关系型数据库和非关系型数据库详解一、引言二、关系型数据库1、关系型数据库简介1.1、SQL语言 2、关系型数据库的实际应用3、关系型数据库的优点4、关系型数据库的缺点 三、非关系型数据库1、非关系型数据库简介1.1、灵活性示例 2、非关系型数据库的分类3、非关系型数…

第8章利用CSS制作导航菜单

8.1 水平顶部导航栏 8.1.1 简单水平导航栏的设计与实现 8.1.1.1导航栏的创建 <nav>标签是 HIML5 新增的文档结构标签&#xff0c;用于标记导航栏&#xff0c;以便后续与网站的其他内整合&#xff0c;所以常用<nav>标签在页面上创建导航栏菜单区域。 例如,在<na…

UniAPP快速入门教程(一)

一、下载HBuilder 首先需要下载HBuilder开发工具&#xff0c;下载地址:https://www.dcloud.io/hbuilderx.htmlhttps://www.dcloud.io/hbuilder.html 选择Windows正式版.zip文件下载。下载解压后直接运行解压目录里的HBuilderX.exe就可以启动HBuilder。 UniApp的插件市场网址…

linux逻辑卷练习

目录 知识点&#xff1a; 常用命令 题目&#xff1a; 解题&#xff1a; 1&#xff09;分区 2&#xff09;创建物理卷 3&#xff09;创建卷组 4&#xff09;生成逻辑卷 "要带参数 -n" 5&#xff09;扩容 6&#xff09;格式化(添加文件系统) 7&#xff09;挂…

【Linux学习】【Ubuntu入门】1-4 ubuntu终端操作与shell命令1

1.使用快捷键CtrlAltT打开命令终端&#xff0c;或者单击右键点击… 2.常用shell命令 目录信息查看命令&#xff1a;ls ls -a&#xff1a;显示目录所有文件及文件夹&#xff0c;包括隐藏文件&#xff0c;比如以.开头的 ls -l&#xff1a;显示文件的详细信息 ls -al&#xff1…

华东师范大学数学分析第五版PDF习题答案上册及下册

“数学分析”是数学专业最重要的一门基础课程&#xff0c;也是报考数学类专业硕士研究生的专业考试科目。为了帮助、指导广大读者学好这门课程&#xff0c;编者编写了与华东师范大学数学科学学院主编的《数学分析》(第五版)配套的辅导用书&#xff0c;以帮助读者加深对基本概念…

iOS逆向入门:使用theos注入第三方依赖库

背景 theos是一个跨平台的软件开发框架&#xff0c;常用于管理&#xff0c;开发和部署iOS项目&#xff0c;同时也是开发iOS越狱插件的主要工具。和MonkeyDev不同的是&#xff0c;它不依赖于xcode&#xff0c;可以在多个操作系统上运行。一个完整的iOS越狱开发流程包括&#xf…

从0开始学习机器学习--Day26--聚类算法

无监督学习(Unsupervised learning and introduction) 监督学习问题的样本 无监督学习样本 如图&#xff0c;可以看到两者的区别在于无监督学习的样本是没有标签的&#xff0c;换言之就是无监督学习不会赋予主观上的判断&#xff0c;需要算法自己去探寻区别&#xff0c;第二张…

【论文模型复现】深度学习、地质流体识别、交叉学科融合?什么情况,让我们来看看

文献&#xff1a;蓝茜茜,张逸伦,康志宏.基于深度学习的复杂储层流体性质测井识别——以车排子油田某井区为例[J].科学技术与工程,2020,20(29):11923-11930. 本文目录 一、前言二、文献阅读-基于深度学习的复杂储层流体性质测井识别2.1 摘要2.2 当前研究不足2.3 本文创新2.4 论文…

STM32设计防丢防摔智能行李箱

目录 目录 前言 一、本设计主要实现哪些很“开门”功能&#xff1f; 二、电路设计原理图 1.电路图采用Altium Designer进行设计&#xff1a; 2.实物展示图片 三、程序源代码设计 四、获取资料内容 前言 随着科技的不断发展&#xff0c;嵌入式系统、物联网技术、智能设备…

【IC每日一题:IC常用模块--RR/handshake/gray2bin】

IC每日一题&#xff1a;IC常用模块--RR/handshake/gray2bin 1 RR仲裁器2 异步握手信号处理3 格雷码和二进制相互转换 1 RR仲裁器 应用&#xff1a;在多个FIFO请求pop时存在仲裁策略&#xff0c;还有比如多master申请总线控制权的仲裁等这些应用场合&#xff1b;假如当前是最高…

从dos上传shell脚本文件到Linux、麒麟执行报错“/bin/bash^M:解释器错误:没有那个文件或目录”

[rootkylin tmp]#./online_update_wars-1.3.0.sh ba51:./online_update_wars-1.3.0.sh:/bin/bash^M:解释器错误:没有那个文件或目录 使用scp命令上传文件到麒麟系统&#xff0c;执行shell脚本时报错 “/bin/bash^M:解释器错误:没有那个文件或目录” 解决方法&#xff1a; 执行…

几何合理的分片段感知的3D分子生成 FragGen - 评测

FragGen 来源于 2024 年 3 月 25 日 预印本的文章&#xff0c;文章题目是 Deep Geometry Handling and Fragment-wise Molecular 3D Graph Generation&#xff0c; 作者是 Odin Zhang&#xff0c;侯廷军&#xff0c;浙江大学药学院。FragGen 是一个基于分子片段的 3D 分子生成模…

【不写for循环】玩玩行列

利用numpy的并行操作可以比纯用Python的list快很多&#xff0c;不仅如此&#xff0c;代码往往精简得多。 So, 这篇来讲讲进阶的广播和花哨索引操作&#xff0c;少写几个for循环&#xff08;&#xff09;。 目录 一个二维的例题 一个三维的例题 解法一 解法二 更难的三维例题…