四面八方
四方门主东方青木看着四面八方涌过来的极客,非常震惊,转头便进入了祖祠中的地下室,发现这丫传自唐朝的密室还设计了英文密码。旁边的石头上(附件中有拓本)刻着密码和密文,大家快帮助门主解出密码(答案为一串通顺语义字符串)
附件:
key1:security
key2:information
密文啊这是,骚年加油:zhnjinhoopcfcuktlj
根据题目描述,此题应该是四方密码
首先选择两个英文字作密匙,例如example和keyword。对于每一个密匙,将重复出现的字母去除,即example要转成exampl,然后将每个字母顺序放入矩阵,再将余下的字母顺序放入矩阵,便得出加密矩阵。
将这两个加密矩阵放在右上角和左下角,余下的两个角放a到z顺序的矩阵:
加密的步骤:
两个字母一组地分开讯息:(例如hello world变成he ll ow or ld);
找出第一个字母在左上角矩阵的位置;
同样道理,找第二个字母在右下角矩阵的位置;
找右上角矩阵中,和第一个字母同行,第二个字母同列的字母;
找左下角矩阵中,和第一个字母同列,第二个字母同行的字母;
根据key1:security
将确认秘钥1:securityabdfghklmnopqvwxz
根据key2:information
确认秘钥2:informatbcdeghklpqsuvwxyz
进行四方解密:
解密结果提交后发现不对,根据题目描述答案为一串通顺语义字符串
,所以还要将其转化为一串通顺语义字符串,最终转化为youngandsuccessful
,年轻且成功应该是了。
麻了麻了,找了个解密脚本,竟然有了脚本就不多bb了,直接用脚本:
#coding:utf-8
import collections
import re
matrix = 'ABCDEFGHIJKLMNOPRSTUVWXYZ'
pla = 'abcdefghijklmnoprstuvwxyz'
key1 = '[SECURITY]'
key2 = '[INFORMATION]'
key1 = ''.join(collections.OrderedDict