www.pythonchallenge.com, 它是一个在线的 Python 技术挑战平台,一共有33道关卡,你只有正确回答了第一道题才能看到第二道题,依此类推
第一次使用这个网站估计你弄不明白怎么玩,因为每道题就是一张图,你要根据每道题的提示信息算出正确答案,正确答案就是下一道题的入口
第一题
它的答案其实就是将2的38次方的结果作为下一道题的入口链接,因为 2**38 等于 274877906944,所以第二道题的链接地址就是将这道题的链接
http://www.pythonchallenge.com/pc/def/0.html
替换成:
http://www.pythonchallenge.com/pc/def/274877906944.html
第二题
打开链接后会重定向到新的页面,出现的图是:
先用代码实现可以得到解密算法:
def decrypt(c):
return chr(((ord(c) + 2) - ord('a')) % 26 + ord('a'))
将加密字符串进行解密得到:
>>> s = """
everybody thinks twice before solving this.
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.
"""
>>> result = ""
>>> for c in raw:
... if c >= 'a' and c <= 'z':
... result += decrypt(c)
... else:
... result += c
最后解密出result为(代码可右划):
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.
它告诉我们不要等手动的去转换,而是用一种算法来实现,因为遇到很长的字符串时手动转换的效率不高,另外它还给了我们另一种方法就是使用 string.maketrans() 进行转换,所以就有了第二种解法:
>>> t = str.maketrans("abcdefghijklmnopqrstuvwxyz", "cdefghijklmnopqrstuvwxyzab")
>>> s.translate(t)
"i hope you didnt translate it by hand. thats what computers are for. doing itin by hand is inefficient and that's why this text is so long. using string.maketrans() is recommended. now apply on the url."
我们将该算法应用到该url
http://www.pythonchallenge.com/pc/def/map.html
将被转换成
http://www.pythonchallenge.com/pc/def/ocr.html
该链接就是第三题的入口
第三题
推荐阅读:
如果喜欢本文,欢迎关注并置顶公众号