====== Python Challenge 第一关:简单加密 ======
===== 题目 =====
同样,题目给出了一幅图片和一段话,明显那一段话是经过加密的。
题目原文:http://www.pythonchallenge.com/pc/def/map.html
{{:challenge:python-challenge-1-map.jpg| Python Challenge 第一关:简单加密 }}
文字说明:
g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq ypc dmp. bmgle gr gl zw fylb gq glcddgagclr ylb rfyr'q ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq() gq pcamkkclbcb. lmu ynnjw ml rfc spj.
===== 解答 =====
根据图片可以得到,这个简单的加密算法是将字符根据字符表的顺序后移两个。
K -> M
O -> Q
E -> G
根据这样的算法,可以给吃一个直观的函数:
#! /tools/cfr/bin/python
import string
def convert(enstr):
newstr = ""
for i in enstr:
if ord(i) >= ord('a') and ord(i) <= ord('z') :
n = ord(i) + 2
if n > ord('z'):
n = n - ord('z') + ord('a') -1
newstr += chr(n)
else:
newstr += i
return newstr
if __name__ == "__main__":
enstr = "g fmnc wms bgblr rpylqjyrc gr zw fylb. rfyrq ufyr amknsrcpq ypc dmp. bmgle gr gl zw fylb gq glcddgagclr ylb rfyr'q ufw rfgq rcvr gq qm jmle. sqgle qrpgle.kyicrpylq() gq pcamkkclbcb. lmu ynnjw ml rfc spj. "
newstr = convert(enstr)
print newstr
可以得到加密文字解密的结果:
i hope you didnt translate it by hand. thats what computers are for. doing it in by hand is inefficient and that's why this text is so long. using string.maketrans() is recommended. now apply on the url.
解密出来文字的意思就是对url进行一遍这个操作。
那么很容易的,这关的 url 是 map.html,进行如下的变换:
m -> o
a -> c
p -> r
那么下一关的url就是ocr.html。
* http://www.pythonchallenge.com/pc/def/ocr.html