网址:chanllenge

修改url最后的html的前缀为答案,就可以过关。

页面上很多只有一幅图片,实际上题目描述全在页面源码中。

然后推荐一个在线代码运行的网站 ideone

查看所有源码:https://github.com/yrhsilence/pythonchallenge

第零题:

题目:要求取2的38次方。

解:python支持**符号表示指数,也可以用match.pow()

  1. 2 ** 38
  2.  
  3. math.pow(2, 38)

第一题:

题目:字符变换,最简单的加密解密方法。

解:字符相差为2,所以把所有的字母的ascci值加2就可以,下面的提示,最终的答案都使用转换既可过关。最傻in hand,不过是会被鄙视的。

  你可以用ord,chr两个内建函数,然后自己编写一个转换函数。

  可以用内建的string.maketrans建立一一对应关系,然后使用translate函数运用该对应关系。

  1. import string
  2.  
  3. a = "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. "
  4. aa = "map"
  5. b = string.maketrans('abcdefghijklmnopqrstuvwxyz', 'cdefghijklmnopqrstuvwxyzab')
  6. print a.translate(b)
  7. print aa.translate(b)

第二题:

题目:获取一个字符串中最少出现的字符。

解:在页面的源码页,你可以获取到这个长字符串,存入文件中,然后读取出来。获取其中所有字符的出现次数,得到最少出现的字符组。按照这个字符组中各字符出现的先后顺序组合成一个字符串,即为答案。

  1. #!/usr/bin/python
  2. import sys
  3.  
  4. fp = open('3.txt', 'r')
  5. con = fp.read()
  6.  
  7. m = {}
  8. for c in con:
  9. m[c] = m.get(c, 0) + 1
  10.  
  11. #print [(k, m[k]) for k in sorted(m.keys())]
  12. #print [v for v in sorted(m.values())]
  13. #sort_m1 = sorted(m.iteritems(), cmp = lambda x, y: cmp(x[1], y[1]), reverse = True)
  14. sort_m = sorted(m.iteritems(), key = lambda d: d[1])
  15.  
  16. result = {}
  17. for i in range(8):
  18. key = sort_m[i][0]
  19. result[key] = con.find(key)
  20.  
  21. sort_r = sorted(result.items(), key = lambda d: d[1])
  22. for item in sort_r:
  23. sys.stdout.write(item[0])
  24. sys.stdout.write('\n')

第三题:

题目:要你找到符合题目描述的字符串,特点是一个小写字母的两边刚好有三个大写字母。

解:在页面的源码中获得长字符串。然后取出符合条件的字符串。把中间的那个小写字符取出来,最后合并即为结果。

  1. !/usr/bin/python
  2.  
  3. #string reverse: s[::-1]
  4.  
  5. import sys
  6.  
  7. fp = open('4.txt', 'r')
  8.  
  9. lines = ""
  10. for line in fp:
  11. lines += line.strip()
  12.  
  13. def filte(s):
  14. return s[1:4].isupper() and s[4].islower() and s[-4:-1].isupper() \
  15. and s[0].islower() and s[-1].islower()
  16.  
  17. for i, _ in enumerate(lines[4:-4]):
  18. word = lines[i:i+9]
  19. if filte(word):
  20. sys.stdout.write(word[4])
  21. sys.stdout.write('\n')

第四题:

题目:根据源码页中题目的提示,需要多次通过urllib获取网页信息,从中提取nothing的值,组成新的url。

解:通过python的urllib库获取网页信息,然后通过re模块获取数值。注意有两点,一中间有一个页面没有数值,只有一个描述语句;二要取最后一个数值。

  1. #!/usr/bin/python
  2.  
  3. import re
  4. import urllib2
  5.  
  6. def get_index(index):
  7. url = 'http://www.pythonchallenge.com/pc/def/linkedlist.php?nothing=' + index
  8. html = urllib2.urlopen(url).read()
  9. print html
  10. result = re.findall('\d+', html)
  11. if (len(result) > 0):
  12. return str(result[-1])
  13. else:
  14. return None
  15.  
  16. index = ''
  17. for i in range(400):
  18. index = get_index(index)
  19. if index == None:
  20. break
  21.  
  22. index = str(16044 / 2)
  23. for i in range(400):
  24. index = get_index(index)
  25. if index == None:
  26. break

python chanllenge题解的更多相关文章

  1. 一人一python挑战题解

    题目id: 1 just print a+b give you two var a and b, print the value of a+b, just do it!! print a+b 题目id ...

  2. 2019-06-03 校内python模拟题解(所有非原题)

    一起来女装吧 本题改编自USACO(USA Computing Olympiad) 1.1节的第一题 (感谢lsy同学对本题题面的贡献) 直接计算就好了 chr:将ASCII码转成字符 ord:字符对 ...

  3. LeetCode python实现题解(持续更新)

    目录 LeetCode Python实现算法简介 0001 两数之和 0002 两数相加 0003 无重复字符的最长子串 0004 寻找两个有序数组的中位数 0005 最长回文子串 0006 Z字型变 ...

  4. The Python Challenge 题解

    仔细阅读,图画下面的提示(网页的 title 也是重要的提示信息,至少告诉你考察的对象是什么) 1. 238 >> 2**38 274877906944L 根据提示,在 URL 地址处,0 ...

  5. 【Python CheckiO 题解】SP

    题目描述 [Speech Module]:输入一个数字,将其转换成英文表达形式,字符串中的所有单词必须以一个空格字符分隔. [输入]:一个数字(int) [输出]:代表数字的英文字符串(str) [前 ...

  6. 【ARTS】01_02_左耳听风-20181119~1125

    Algorithm 做一个 leetcode 的算法题 Unique Email Addresses https://leetcode.com/problems/unique-email-addres ...

  7. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  8. [LeetCode]题解(python):125 Valid Palindrome

    题目来源 https://leetcode.com/problems/valid-palindrome/ Given a string, determine if it is a palindrome ...

  9. [LeetCode]题解(python):120 Triangle

    题目来源 https://leetcode.com/problems/triangle/ Given a triangle, find the minimum path sum from top to ...

随机推荐

  1. 在CentOS 7上安装phpMyAdmin

    原文 在CentOS 7上安装phpMyAdmin phpMyAdmin是一款以PHP为基础,基于Web的MySQL/MariaDB数据库管理工具.虽然已经存在着一些诸如Adminer的轻量级数据库管 ...

  2. C#开发人员能够可视化操作windows服务

    使用C#开发自己的定义windows服务是一个很简单的事.因此,当.我们需要发展自己windows它的服务.这是当我们需要有定期的计算机或运行某些程序的时候,我们开发.在这里,我有WCF监听案例,因为 ...

  3. How to recover from 'programmers burnout(转)

    程序员这个压力大,节奏快,任务繁重,所以很容易令人感觉倦怠,令人感觉烦躁,郁闷,疲惫不堪. 本文将介绍的是程序员如何克服可怕的“职业倦怠”. 丰盛的早餐——身处高科技产业漩涡的我们常常会熬夜到凌晨两三 ...

  4. Android ADT Bundle(Eclipse with ADT) ADT R23

    ADT Bundle Platform Package Size MD5 Checksum Windows 32-bit adt-bundle-windows-x86-20140624.zip 377 ...

  5. HDU 1877 另一个版本 A+B

    另一个版本 A+B Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  6. 1023 Train Problem II(卡特兰数)

    Problem Description As we all know the Train Problem I, the boss of the Ignatius Train Station want ...

  7. C语言中符号格式说明

    scanf 语法: #include <stdio.h>int scanf( const char *format, ... ); scanf()函数根据由format(格式)指定的格式从 ...

  8. Fireasy

    Fireasy与Asp.net MVC结合   Fireasy之前都是使用HttpService来为jquery ajax提供服务,这个HttpService实际上和MVC的原理机制是一样的,只是它支 ...

  9. Android - View Alpha值

    Android - View Alpha值 本文地址: http://blog.csdn.net/caroline_wendy Alpha值主要控制图像的透明度(0-1),0代表透明.1代表不透明. ...

  10. 信号量机制DOWN操作和UP操作的详细说明

    DOWN操作:linux内核.信号DOWN例如,下面的操作: void down(struct semaphore *sem); //不间断 int down_interruptible(struct ...