打开第五关,看到一坐山,山上有座庙,庙里有个老和尚和小和尚,老和尚给小和尚讲:打开第五关,看到一座山......
对不起实在编不下去了,不过还是提一句这个老和尚真的是递归鼻祖啊哈哈哈。
言归正传,看到提示是:pronounce it,于是拼读peak,匹克~,好像并没有什么卵用。
于是打开源代码,发现要你拼读的是peak hell......,那不就是pickle嘛,这是个python模块!
同时源代码中还为我们用peakhell块标出了banner.p文件,于是大概就明白了是要我们用pickle块去解析banner.p文件
于是又勤劳地码代码了:
import pickle
p=pickle.load(file('mission5data'))
for item in p:
print item
输出结果不明觉厉啊:
[(' ', 95)]
[(' ', 14), ('#', 5), (' ', 70), ('#', 5), (' ', 1)]
[(' ', 15), ('#', 4), (' ', 71), ('#', 4), (' ', 1)]
......以下省去一万字输出
不过根据输出的list of tupple大概能猜测出来第一行是95个空格,第二行是14个空格加上个#加上70个空格加上5个#最后再加上1个空格,后面以此类推。
我们可以定义一个函数来遍历每行列表然后输出tuple[0]*tuple[1]的连接,然而我们不准备这么做,我们打算用lambda表达式来完成这一任务:
import pickle
p=pickle.load(file('mission5data'))
for item in p:
# print item
print "".join(map(lambda p: p[0]*p[1], item))
然后就可以看到amazing的输出结果:
输入网址http://www.pythonchallenge.com/pc/def/channel.html进入下一关