溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python如何實現(xiàn)仿射密碼

發(fā)布時間:2020-07-31 10:49:19 來源:億速云 閱讀:197 作者:小豬 欄目:開發(fā)技術(shù)

這篇文章主要為大家展示了Python如何實現(xiàn)仿射密碼,內(nèi)容簡而易懂,希望大家可以學習一下,學習完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。

仿射密碼思路:

1、加解密公式:

Python如何實現(xiàn)仿射密碼

2、構(gòu)造對應(yīng)字典:

Python如何實現(xiàn)仿射密碼

3、代碼實現(xiàn)

構(gòu)造字典,建立映射關(guān)系:

# 構(gòu)造字典,'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}']


# 構(gòu)造字典,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='')

實現(xiàn)加密:

# 編碼
def encode():
  s = input('輸入需要編碼的字符: ')
  print('編碼后的結(jié)果為: ',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的逆,實現(xiàn)解密:

# 求模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('解碼后的結(jié)果為: ',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)

函數(shù)入口:

# 輸入指令
answer = input(f'請輸入所需的操作:編碼/E or 解碼/D: ')

# 輸入?yún)?shù)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
編碼后的結(jié)果為: YZWHX VT TZ QZY

解密效果:

請輸入所需的操作:編碼/E or 解碼/D:  D
請輸入a:5
請輸入b: 7
輸入需要解碼的字符: YZWHX VT TZ QZY
解碼后的結(jié)果為: TODAY IS SO HOT

以上就是關(guān)于Python如何實現(xiàn)仿射密碼的內(nèi)容,如果你們有學習到知識或者技能,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI