仿射加密

本文介绍了一个基于仿射变换的加密算法实现,包括加密与解密过程。通过定义字母表、最大公约数计算、求逆元等函数,实现了文本的加密与解密功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#####################仿射加密####################

letter_list="ABCDEFGHIJKLMNOPQRSTUVWXYZ"  #字母表

#gcd函数,求最大公约数
def gcd(a,b):
  if(a<b):
    t=a
    a=b
    b=t
    
  while(0!=b):
    t=a
    a=b
    b=t%b
  return a

#求逆元函数
def GetInverse(a,m):
  for i in range(m):
    if(1==(a*i)%m):
      return i

#加密函数
def Encrypt(plaintext,key1,key2):
  ciphertext=""
  for ch in plaintext:  #遍历明文
    if ch.isalpha():  #明文是否为字母,如果是,则判断大小写,分别进行加密
      if ch.isupper():  
        ciphertext+=letter_list[(key1*(ord(ch)-65)+key2) % 26]
      else:
        ciphertext+=letter_list[(key1*(ord(ch)-97)+key2) % 26].lower()
    else: #如果密文不为字母,直接添加到密文字符串里
      ciphertext+=ch
  return ciphertext

#解密函数
def Decrypt(ciphertext,key1,key2):
  plaintext=""
  for ch in ciphertext: #遍历密文
    if ch.isalpha():  #密文为否为字母,如果是,则判断大小写,分别进行解密
      if ch.isupper():
        plaintext+=letter_list[GetInverse(key1,26)*(ord(ch)-65-key2) % 26]
      else:
        plaintext+=letter_list[GetInverse(key1,26)*(ord(ch)-97-key2) % 26].lower()
    else: #如果密文不为字母,直接添加到明文字符串里
      plaintext+=ch
  return plaintext

#主函数
print("加密请按D,解密请按E:")
user_input=input();
while(user_input!='D' and user_input!='E'):#输入合法性判断
  print("输入有误! 请重新输入:")
  user_input=input()

print("请输入两个密钥,且gcd(key1,26)==1:")
key1=input("key1:")
key2=input("key2:")
while(1): #输入合法性判断
  if(0==int(key1.isdigit()) or 0==int(key2.isdigit())):
    print("输入有误! 密钥为数字,请重新输入:")
    key1=input("key1:")
    key2=input("key2:")
  elif(gcd(int(key1),26)!=1):
    print("输入有误! key1和26必须互素,请重新输入:")
    key1=input("key1:")
    key2=input("key2:")
  else:
    break;

if user_input=='D':
  #加密
  print("请输入明文:")
  plaintext=input()
  ciphertext=Encrypt(plaintext,int(key1),int(key2))
  print("密文为:\n%s" % ciphertext)
else:
  #解密
  print("请输入密文:")
  ciphertext=input()
  plaintext=Decrypt(ciphertext,int(key1),int(key2))
  print("明文为:\n%s" % plaintext)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值