另一个比较有名的古典密码*是代换密码。
在移位密码中,加密和解密都是代数运算,但是在代换密码中,可以认为P和C是26个英文字母,并且可以认为加密和解密的过程直接看作是在一个字母表上的置换。
任意取一置换,即可得到加密函数,见下表(小写字母表示明文,大写字母表示密文):
按照上表有,等等。而解密函数则是相应的逆置换。
代码实现(Python 3)
def substitution_cipher_encrypt(message:str): SYMBOLS_PLAINTEXT = 'abcdefghijklmnopqrstuvwxyz' SYMBOLS_CIPHERTEXT= 'XNYAHPOGZQWBTSFLRCVMUEKJDI' translated = '' message = message.lower() for symbol in message: if symbol in SYMBOLS_PLAINTEXT: symbolIndex = SYMBOLS_PLAINTEXT.find(symbol) translated = translated + SYMBOLS_CIPHERTEXT[symbolIndex] else: translated = translated + symbol print(translated) def substitution_cipher_decrypt(message:str): SYMBOLS_CIPHERTEXT= 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' SYMBOLS_PLAINTEXT = 'dlryvohezxwptbgfjqnmuskaci' translated = '' message = message.upper() for symbol in message: if symbol in SYMBOLS_CIPHERTEXT: symbolIndex = SYMBOLS_CIPHERTEXT.find(symbol) translated = translated + SYMBOLS_PLAINTEXT[symbolIndex] else: translated = translated + symbol print(translated)