Hello,大家好,小编最近在学习廖雪峰老师官网的Python3,想通过解答每节知识点后的练习题的的方式来检验自己的学习成果,也希望能帮助和小编一样的小白解决心中的疑惑,大家共同进步。
(1)切片练习题:
利用切片操作,实现一个trim()函数,去除字符串首尾的空格,注意不要调用str的strip()方法:
代码部分:
# -*- coding: utf-8 -*-
def trim(s):
while s[:1]==' ':
s = s[1:]
while s[len(s)-1:]==' ':
s = s[:len(s)-1]
return s
注意:切片在选取的时候是取第一个坐标(包含)与第二个坐标(不包含)的中间部分。
(2)迭代练习题:
请使用迭代查找一个list中最小和最大值,并返回一个tuple:
代码部分:
# -*- coding: utf-8 -*-
def findMinAndMax(L):
if L ==[]:#判断是否为空
return(None,None)
else:
a = L[0]
b = L[0]
for x in L: #遍历列表
if x>a: #取出每个元素与第一个元素比较,并将最大值输出
a=x
elif x<b: #取出每个元素与第一个元素比较,并将最小值输出
b=x
return(b,a)
(3)列表生成式练习题:
请修改列表生成式,通过添加if语句保证列表生成式能正确地执行:
代码部分:
# -*- coding: utf-8 -*-
L1 = ['Hello', 'World', 18, 'Apple', None]
L2 = [s.lower() for s in L1 if isinstance(s,str)]
#如果是字符串的话就将其转化为小写,并写进L2中
(4)生成器练习题:
杨辉三角定义如下:

把每一行看做一个list,试写一个generator,不断输出下一行的list:
代码部分:
# -*- coding: utf-8 -*-
def triangles():
L = [1] #首先定义第一个列表,输出[1]
while True:
yield L #这是生成器与普通函数的差别,遇到yield就中断,下次又会继续执行
L= [(L + [0])[i] + ([0] + L)[i] for i in range(len(L)+1)]
这是我在网上看到大神们给出的超简单的方法,大家一看最后的公式是不是有点蒙啊?接下来小编就给你解释一下。首先我们要知道杨辉三角的规律:我们先将图像抽象化转化为列表
[1]
[1, 1]
[1, 2, 1]
[1, 3, 3, 1]
[1, 4, 6, 4, 1]
[1, 5, 10, 10, 5, 1]
[1, 6, 15, 20, 15, 6, 1]
[1, 7, 21, 35, 35, 21, 7, 1]
[1, 8, 28, 56, 70, 56, 28, 8, 1]
[1, 9, 36, 84, 126, 126, 84, 36, 9, 1]
可以看出下一列都是上一列的对应位置的元素与前一个元素的和。没有前一个元素或者后一个元素的默认为0,举例说明一下
L=[1,5,10,10,5,1] 将L前后补0形成L1和L2即
L1=[0,1,5,10,10,5,1]
L2=[1,5,10,10,5,1,0]
则 L3的值便是0+1=1,1+5=6,5+10=15,10+10=20,10+5=15,5+1=6,1+0=1
所以下一列元素就是L3=[1,6,15,20,15,6,1]
所以我们抽象成代码 [(L + [0])[i] + ([0] + L)[i]
然后我们发现下一行都比上一行多一,所以得到for i in range(len(L)+1)
综上这就是在廖雪峰老师的官网Python3中的高级特性练习题了。大家有什么不懂得地方欢迎留言,如果小编哪里写错了或者您有更好的解决方案,请联系小编吧!小编期望与您共同进步。
网友评论