Python挑战题

栏目: IT技术 · 发布时间: 4年前

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

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

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

Python挑战题

第一题

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

Python挑战题

>>> 2**38
274877906944

第二题

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

Python挑战题

通过图中提示,我们发现字符向右移动了两位,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源代码中

Python挑战题

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

Python挑战题

我们可以直接使用 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挑战题

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Python带我起飞

Python带我起飞

李金洪 / 电子工业出版社 / 2018-6 / 79

《Python带我起飞——入门、进阶、商业实战》针对Python 3.5 以上版本,采用“理论+实践”的形式编写,通过大量的实例(共42 个),全面而深入地讲解“Python 基础语法”和“Python 项目应用”两方面内容。书中的实例具有很强的实用性,如对医疗影像数据进行分析、制作爬虫获取股票信息、自动化实例、从一组看似混乱的数据中找出规律、制作人脸识别系统等。 《Python带我起飞——......一起来看看 《Python带我起飞》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具