python实现凯撒密码、凯撒加解密算法
作者:c_programj 发布时间:2023-08-27 17:49:22
标签:python凯撒密码,凯撒加解密,算法
凯撒密码的原理:计算并输出偏移量为3的凯撒密码的结果
注意:密文是大写字母,在变换加密之前把明文字母都替换为大写字母
def casar(message):
# *************begin************#
message1=message.upper() #把明文字母变成大写
message1=list(message1) #将明文字符串转换成列表
list1=[]
for i in range(len(message1)):
if message1[i]==' ':
list1.append(message1[i]) #若为空格不用移动
elif ord(message1[i]) <= 90-3+1: #A-X右移三位
list1.append(chr(ord(message1[i]) + 3))
result = ''.join(list1) #列表转换成字符串
else:
list1.append(chr(ord(message1[i]) - (26-3))) #Y和Z回到A、B
result = ''.join(list1)
print(result)
# **************end*************#
def main():
message = input()
casar(message)
if __name__=='__main__':
main()
测试输入:Guet
预期输出:JXHW
测试输入:information security
预期输出:LQIRUPDWLRQ VHFXULWB
凯撒密码原理:根据输入的加解密模式和密钥对消息进行加解密。
注意:如果是加密,输出的密文是大写字母,如果是解密,按照凯撒解密后,转换为小写后,输出解密后的明文.
def casar(mode,message,key):
# *************begin************#
if mode==1: #加密
message1 = message.upper() # 把明文字母变成大写
message1 = list(message1) # 将明文字符串转换成列表
list1 = []
for i in range(len(message1)):
if message1[i] == ' ':
list1.append(message1[i]) # 若为空格不用移动
elif ord(message1[i]) <= 65 +key-1:
list1.append(chr(ord(message1[i]) + key)) # 右移key位
result = ''.join(list1) # 列表转换成字符串
else:
list1.append(chr(ord(message1[i]) - key))
result = ''.join(list1)
print(result)
elif mode==0: #解密
message2 = list(message) # 将明文字符串转换成列表
list2 = []
for i in range(len(message2)):
if message2[i] == ' ':
list2.append(message2[i]) # 若为空格不用移动
elif ord(message2[i]) <= 65+ key -1:
list2.append(chr(ord(message2[i]) + (26-key))) # 右移三位
result = ''.join(list2) # 列表转换成字符串
else:
list2.append(chr(ord(message2[i]) - key))
result = ''.join(list2)
result = result.lower()
print(result)
# **************end*************#
def main():
mode = int(input()) # 1代表加密,0代表解密
message = input() #待加密或解密的消息
key = int(input()) # key的范围0~25之间
casar(mode,message,key)
if __name__=='__main__':
main()
测试输入:
1
zhang
13
测试输出:
MUNAT
测试输入:
0
GOHUN
7
测试输出:
zhang
编写一个仿射加解密程序,范围是所有的大小写字母范围
本题需要掌握相关知识1.仿射加密算法,2.扩展的欧几里得算法。
假设X,Y,a,b是Z52整数环中的元素,a和b为密钥,X是原文,Y是密文
加密函数:Y=(aX+b)%52
获取乘法逆元
通过扩展的欧几里得算法求a的乘法逆元
加密过程
加密函数:Y=(aX+b)%52
解密过程
解密函数:X=(a的逆元)*(Y-B)%52
#仿射密码
def encrypt(k1,k2,message):
# *************begin************#
message1 = list(message)
list1=list(map(chr,range(ord('a'),ord('z')+1)))
list2=list(map(chr,range(ord('A'),ord('Z')+1)))
for i in range(len(list1)):
list1.append(list2[i])
y=[]
for i in range(len(message)):
if message1[i]==' ':
y.append(message1[i])
else:
for j in range(52):
if message1[i]==list1[j]:
y.append(list1[(k1*j + k2) % 52])
result = ''.join(y)
return result
# **************end*************#
def decrypt(k1,k2,message):
# *************begin************#
#扩展欧几里得算法求逆元法
# x1, x2, x3 = 1, 0, 52
# y1, y2, y3 = 0, 1, k1
# while True:
# if y3 == 0:
# return 'None'
# break
# elif y3 == 1:
# a_reverse =y2 % 52
# break
# else:
# Q = x3 // y3
# t1, t2, t3 = x1 - Q * y1, x2 - Q * y2, x3 - Q * y3
# x1, x2, x3 = y1, y2, y3
# y1, y2, y3 = t1, t2, t3
#已知模求逆元
for i in range(1,53):
if k1 * i % 52 == 1:
a_reverse = i
message1 = list(message)
list1=list(map(chr,range(ord('a'),ord('z')+1)))
list2=list(map(chr,range(ord('A'),ord('Z')+1)))
for i in range(len(list1)):
list1.append(list2[i])
x=[]
for i in range(len(message1)):
if message1[i]==' ':
x.append(message1[i])
else:
for j in range(52):
if message1[i]==list1[j]:
x.append(list1[(a_reverse * (j-k2) )% 52])
result = ''.join(x)
return result
# **************end*************#
def main():
mode = int(input()) # 1代表加密,0代表解密
message = input() #待加密或解密的消息
key1 = int(input()) # key的范围0~51之间
key2 = int(input()) # key的范围0~51之间
if mode == 1:
translated = encrypt(key1,key2,message)
else:
translated = decrypt(key1,key2,message)
print(translated)
if __name__=='__main__':
main()
测试输入:
1
zhang
7
31
预期输出:
YCFsv
测试输入:
0
gVEXGT iDIT
5
29
预期输出:
Lovely Baby
来源:https://blog.csdn.net/c_programj/article/details/106668665


猜你喜欢
- 核心代码由于HttpServletRequest不能直接取出文件数据,所以将其强制转换为MultipartHttpServletReques
- 家里没网络,实在无聊,玩游戏都没味道,只好玩CSS。这个东西实在没什么技术含量在里面,纯属打发时间。简单说明:一张图片放在底层,
- Python 编程中使用 time 模块可以让程序休眠,具体方法是time.sleep(秒数),其中“秒数”以秒为单位,可以是小数,0.1秒
- 微软的SQL Server 2005中用来替代数据传输服务(DTS)的SQL Server综合服务(SSIS),包含了很多工具用于导入数据并
- 大家都知道,数据库的安全性是很重要的,它直接影响到数据库的广泛应用。用户可以采用任意一种方法来保护数据库应用程序,也可以将几种方法结合起来使
- python语言本身没有提供const,但实际开发中经常会遇到需要使用const的情形,由于语言本身没有这种支出,因此需要使用一些技巧来实现
- 最近有用到对存储过程(procedure)重命名的功能,在网上找了一下资料都没有讲到在mysql中是如何实现的,当然可以删掉再重建,但是应该
- 一 使用SELECT子句进行多表查询SELECT 字段名 FROM 表1,表2 …&nbs
- 本文实例讲述了python中for语句简单遍历数据的方法。分享给大家供大家参考。具体如下:for name in ["kak&qu
- 本文实例讲述了Selenium基本用法。分享给大家供大家参考,具体如下:Selenium是一个用于Web应用程序测试的工具。Selenium
- 通常我们做统计图的时候需要借助组件来完成例如mschart,aspchart等但是这个类不需要任何组件,而且使用方便,本站测试可用:clsG
- 内容摘要:本文介绍了对数据库的基本操作:数据记录筛选(select),更新数据库(update),删除记录(delete),添加数据记录(i
- 1、一个或多个文件夹组成一个模块,而一个模块组合构成了一个包发布在公共目录里。2、包必须有__init__文件,否则就是一个文件夹。实例im
- 1.锁生活中:锁在我们身边无处不在,比如我出门玩去了需要把门锁上,比如我需要把钱放到保险柜里面,必须上锁以保证我财产的安全。代码中:比如多个
- 概要介绍mmpi,是一款使用python实现的开源邮件快速检测工具库,基于community框架设计开发。mmpi支持对邮件头、邮件正文、邮
- 这篇文章主要介绍了python实现简单日志记录库glog的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,
- 本文实例讲述了mysql共享锁与排他锁用法。分享给大家供大家参考,具体如下:mysql锁机制分为表级锁和行级锁,本文就和大家分享一下我对my
- 1,登录后默认自动选中My Objects 默认情况下,PLSQL Developer登录后,Brower里会选择All objects,如
- 如果你是pytorch的用户,可能你会很熟悉pytorch生态圈中专门预处理图像数据集的torchvision库。从torchtext这个名
- 1.新式类与经典类在Python 2及以前的版本中,由任意内置类型派生出的类(只要一个内置类型位于类树的某个位置),都属于“新式类”,都会获