Python挑战题

By 刘志军 , 2020-05-07, 分类: python

python

网址:http://www.pythonchallenge.com/

这个网站提供了33道智力题,需要用Python里面的一些知识去解决,当然你也可以使用其他语言,每道题都有解题线索,你要根据提示获取答案后才能进入下一题。截至目前,已经有3369095位用户试图发起挑战。

微信截图_20200424150613.png

第一题

第一题是热身题,你要计算2的38次幂,计算结果就是第二题的入口链接

微信截图_20200424153058.png

>>> 2**38
274877906944

第二题

第二题的入口链接是 http://www.pythonchallenge.com/pc/def/274877906944.html ,如果你懂凯撒密码的话,你就知道怎么解这道题了。凯撒密码就是将字符移动固定位数得到一个新的字符。

微信截图_20200424154545.png

通过图中提示,我们发现字符向右移动了两位,K变成了M,O 变成了Q

>>> chr(ord('K')+2)
'M'
>>> chr(ord('O')+2)
'Q'
>>> chr(ord('E')+2)
'G'

因此,可以我们只需要把图片下方这串加密的文本进行解码就可以得到正确的文本。

text = "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."
s = ""
for i in text:
    import string

    if i in string.ascii_letters:
        if ord(i) < 121:
            s += chr((ord(i) + 2))
        else:
            s += chr((ord(i) - 26 + 2))
    else:
        s += i
print(s)

结果

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.

这里有两个需要注意的地方,第一:非字符不需要处理,第二:当字符对应的asscii值大于121(对应的字符是y),需要减 26,相当于 y对应的a。 解码出来后提示告诉我们其实可以直接使用函数string.maketrans(),因为这种方式更高效,不得不说,这道理很有趣。 不过这种方式在python3已经不支持了。

所以第三题的链接只要将map转换成ocr 既可。

第三题

第三题链接: http://www.pythonchallenge.com/pc/def/ocr.html, 这道题根据提示说是答案可能存在于页面的HTML源代码中

微信截图_20200424162517.png

提示告诉我们要把注释里面最少出现的字符找出来

微信截图_20200424164434.png

我们可以直接使用Counter这个类来处理

text = """%%$@_$^__#)^)&!_+]!*@&^}@[@%]()%+$&[(_@%+%$*^@$^!+]!&_#)_*}{}}!}_]$[%}@[{_@#_^{*
{!!"""

from collections import Counter
counter = Counter(text)
for c in counter.items():
    print(c)

输出结果

('%', 6104)
('$', 6046)
('@', 6157)
('_', 6112)
('^', 6030)
('#', 6115)
(')', 6186)
('&', 6043)
('!', 6079)
('+', 6066)
(']', 6152)
('*', 6034)
('}', 6105)
('[', 6108)
('(', 6154)
('{', 6046)
('\n', 1219)
('e', 1)
('q', 1)
('u', 1)
('a', 1)
('l', 1)
('i', 1)
('t', 1)
('y', 1)

发现出现最少的是 equality 这几个字符,刚好可以组成一个单词,这个单词大概就是第四题的链接。http://www.pythonchallenge.com/pc/def/equality.html

梦想是让8岁儿童也能开发属于自己的APP,我很好奇这背后究竟会是一家什么样的公司,今天周末,推荐这篇文给你


关注公众号「Python之禅」,回复「1024」免费获取Python资源

python之禅

猜你喜欢

2024-03-04
Python中的 if __name__ == '__main__' 是什么?
2024-03-04
用 Python 破解隔壁老王家的 Wi-Fi 密码,刺激!
2023-06-12
Python3.12新特性
2023-04-17
Python虚拟环境使用
2023-04-15
如何删除macOS系统默认的Python2.7并替换成最新版python3.11
2022-12-09
python 中return和yield有什么区别
2022-08-17
如何利用多态干掉 if else 语句
2022-07-22
10个python初学者常犯的错误
2022-06-10
flask-siwadoc 支持openapi 分组功能
2022-06-10
在Python应用中Telegram 机器人搭建消息提醒