1. 程式人生 > 程式設計 >Python實現仿射密碼的思路詳解

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,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='')
    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

到此這篇關於Python實現仿射密碼的思路詳解的文章就介紹到這了,更多相關python 仿射密碼內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!