Python实现仿射密码的思路详解
作者:SFS_Ccjm 发布时间:2021-04-17 22:32:00
标签:python,仿射密码
仿射密码思路:
1、加解密公式:
2、构造对应字典:
3、代码实现
构造字典,建立映射关系:
# 构造字典,'A' --> 0 ...
def char_2_num(x):
list_s = []
list_num = []
for i in range(26):
c = chr(i + 65)
list_s.append(c)
list_num.append(i)
c_2_n = dict(map(lambda x, y: [x, y], list_s, list_num))
return c_2_n[f'{x}']
# 构造字典,0 ---> 'A' ...
def num_2_char(x):
list_s = []
list_num = []
for i in range(26):
c = chr(i + 65)
list_s.append(c)
list_num.append(i)
n_2_c = dict(map(lambda x, y: [x, y], list_num, list_s))
print(n_2_c[x],end='')
实现加密:
# 编码
def encode():
s = input('输入需要编码的字符: ')
print('编码后的结果为: ',end='')
for j in s:
if j.isspace():
print(' ',end='')
else:
ek = a * char_2_num(j) + b
result = ek % 26
num_2_char(result)
求模26下a的逆,实现解密:
# 求模26下a的逆
def inv_(x):
for inv_a in range(1,26,2):
for j in range(27):
if x * inv_a == 26 * j + 1:
return inv_a
# 解码
def decode():
s = input('输入需要解码的字符: ')
print('解码后的结果为: ',end='')
for j in s:
if j.isspace():
print(' ',end='')
else:
dk = inv_(a) * (char_2_num(j) - b)
result = dk % 26
num_2_char(result)
函数入口:
# 输入指令
answer = input(f'请输入所需的操作:编码/E or 解码/D: ')
# 输入参数a,b
a = int(input('请输入a:'))
b = int(input('请输入b: '))
try:
if answer.upper() == 'E':
encode()
elif answer.upper() =='D':
decode()
else:
print('输入错误!')
except KeyError:
print('请正确输入大写字母!')
加密效果:
请输入所需的操作:编码/E or 解码/D: E
请输入a:5
请输入b: 7
输入需要编码的字符: TODAY IS SO HOT
编码后的结果为: YZWHX VT TZ QZY
解密效果:
请输入所需的操作:编码/E or 解码/D: D
请输入a:5
请输入b: 7
输入需要解码的字符: YZWHX VT TZ QZY
解码后的结果为: TODAY IS SO HOT
来源:https://blog.csdn.net/SFS_Ccjm/article/details/105660224


猜你喜欢
- 本文实例讲述了Python实现测试磁盘性能的方法。分享给大家供大家参考。具体如下:该代码做了如下工作:create 300000 files
- 经测试可用的发送邮件代码:import smtplibfrom email.mime.text import MIMEText# 第三方 S
- 使用torch.utils.data.Dataset类 处理图片数据时,1. 我们需要定义三个基本的函数,以下是基本流程class our_
- 注册模块default.asp 代码如下:<!DOCTYPE html PUBLIC "-//
- 先说结论1. oracle: oracle 默认没有排序规则2. mysql2.1 innoDB引擎: 默认查询按照id正序排序2.2 my
- 1. union合并查询结果集查询工作岗位是 MANAGER 和 SALESMAN 的员工?mysql> select ename,
- window.onload=function(){ pd(11);} function pd(number) { if(number>
- 我就废话不多说了,大家还是直接看代码吧!database = [ { "name"
- asp三天学好ADO对象之第一天 今天说一下Recordset 对象的属性1、CursorType 属性AdOpenForwardOnly:
- 区域(Area)是一个 ASP.NET MVC 功能,用于将相关功能组织为一个单独的命名空间(用于路由)和文件结构(用于视图)。使用区域通过
- 一、什么是ttkbootstrap?官方文档 [较慢]:https://ttkbootstrap.readthedocs.io/en/lat
- SQLSTATESQL SERVER 驱动程序错误描述 HY000所有绑定列都是只读的。必须是可升级的列,以使用 SQLSetPos 或 S
- 我们在做深度学习的过程中,经常面临图片样本不足、不平衡的情况,在本文中,作者结合实际工作经验,通过图像的移动、缩放、旋转、增加噪声等图像变换
- 引言这三个排序方法应对日常工作基本够用先说一下三者的区别sort, sorted 是用在 list 数据类型中的排序方法argsort 是用
- 1.SQL Server2019安装包下载1.1进入官网SQL Server 20191.2下载安装包1点击Continue2.填写个人信息
- 前言:python利用matplotlib库中的plt.ion()函数实现即时数据动态显示:1.非定长的时间轴代码示例:# -*- codi
- 环境:MacOS_Cetalina_10.15.1、Mysql8.0.18、Docker_2.0.0.31、docker仓库搜索mysqld
- 饼图概念饼图(pie chart)是用圆形及圆内扇形的角度来表示数值大小的图形,它主要用于表示一个样本(或总体)中各组成部分的数据占全部数据
- 1、引言小丝:鱼哥,还记得上次写的把数据库的查询结果写入到excel这个脚本不。小鱼:嗯… 可以说不记得吗小丝:我猜你
- parseInt()是内置的 JS 函数,用于解析数字字符串中的整数。 例如,解析数字字符串'100':const numb