Python實現(xiàn)仿射密碼的思路詳解
仿射密碼思路:
1、加解密公式:

2、構造對應字典:

3、代碼實現(xiàn)
構造字典,建立映射關系:
# 構造字典,'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='')
實現(xiàn)加密:
# 編碼
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的逆,實現(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('解碼后的結果為: ',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
編碼后的結果為: YZWHX VT TZ QZY
解密效果:
請輸入所需的操作:編碼/E or 解碼/D: D
請輸入a:5
請輸入b: 7
輸入需要解碼的字符: YZWHX VT TZ QZY
解碼后的結果為: TODAY IS SO HOT
到此這篇關于Python實現(xiàn)仿射密碼的思路詳解的文章就介紹到這了,更多相關python 仿射密碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
pandas實現(xiàn)datetime64與unix時間戳互轉
這篇文章主要介紹了pandas實現(xiàn)datetime64與unix時間戳互轉,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07

