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,ba = 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 仿射密碼內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!
相關文章:
