python3教材答案_Python3高级特性习题解析

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=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)生成器练习题:

杨辉三角定义如下:

07ba059f8d4d?utm_campaign

把每一行看做一个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中的高级特性练习题了。大家有什么不懂得地方欢迎留言,如果小编哪里写错了或者您有更好的解决方案,请联系小编吧!小编期望与您共同进步。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值