• http://www.pythonchallenge.com/ 网站题解


    在知乎中无意发现了这个网站,做了几题发现挺有趣的,这里记录下自己的解题思路,顺便对比下答案中的思路

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

    目前只做了几题,解题的方法就是根据页面上给的提示(文字或图片),然后得出一个字符串xxxhttp://www.pythonchallenge.com/pc/def/xxx.html 就是下一题的url。下面统一用一个字符串代表xxx这个答案。

     网站的参考答案中给出的答案是更pythonic的。


    第1题:

    http://www.pythonchallenge.com/pc/def/0.html

    算是让你熟悉规则的题,告诉你怎么到下一关。

    因为与python有关,以为结果串 2**38,后面再试下发现是这个计算的结果。

    所以答案是 274877906944


    第2题:

    http://www.pythonchallenge.com/pc/def/map.html

     

    这是一题规则题,根据图中的提示:K->M、O->Q、E->G 可以发现其规律就是字母表对应的后移两位,即 'abcdefghijklmnopqrstuvwxyz' -> 'cdefghijklmnopqrstuvwxyzab'。

    找到规律后,就用此规律转化下面红紫色的语句:

    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="""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."""
    source='abcdefghijklmnopqrstuvwxyz'

    target='cdefghijklmnopqrstuvwxyzab'

    tran_dict=dict(zip(source, target))

    result=''

    for _s in s:

      result += tran_dict.get(_s, _s)

    print 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.

    按这规则转化url里的字符串:

      map -> ocr

    答案为 orcr

    过关后可以看得到参考答案,这里只提一下它的做法:

    1、使用ord、chr(字符与ASCII码数值间转换)

    2、使用string.maketrans和translate
      table = string.maketrans('abcdefghijklmnopqrstuvwxyz','cdefghijklmnopqrstuvwxyzab')
      ’text to be translated'.translate(table)


    第3题:

     http://www.pythonchallenge.com/pc/def/ocr.html

    这题让我蒙了一阵子,不知道突破点在哪,可能是英文太差一直没反应过来,后面注意到 the page source,于是就打开了网页源码

     

    发现突破口是在这,找出下面一大串字符中 rare 字符,便是统计这大串字符的各字符出现个数。

    我的代码:

    s="""%%$@_$^__#)^)&!_+]!*@&^}@..."""  //这串不打出来了

    d={}

    l=[]

    for _s in ss: 

      if _s not in d:

        d[_s] = 0 

        l.append(_s)

      d[_s] += 1

    print d

    print l

    然后看打印

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

    可见应该要找出现个数为1的,按出现顺序输出

    答案为:equality

    参考答案:

    1、使用字符串的 count 函数,可以计算出字符串中某字符的出现个数


    第4题:

     http://www.pythonchallenge.com/pc/def/equality.html

    持续更新中。。。

  • 相关阅读:
    java基础2(Map)
    java基础1
    数据类型
    入门&常量&变量
    spark 机器学习 朴素贝叶斯 原理(一)
    spark 机器学习 knn 代码实现(二)
    spark 机器学习 knn原理(一)
    spark 机器学习 ALS原理(一)
    数学符号表及读法
    spark 机器学习基础 数据类型
  • 原文地址:https://www.cnblogs.com/GO-NO-1/p/8336605.html
Copyright © 2020-2023  润新知