python第十五天

今日内容

1.生成器的send方法。

2.递归:函数自己调用自己

3.匿名函数

4.内置函数

生成器send方法

send的工作原理

1.send发生信息给当前停止的yield

2.再去调用__next__()方法,然后生成器继续往下走,返回下一个yield值并停止

案例:

persons = ['张三', '李四', '王五', '赵六', '钱七']

def order(persons):
for i in range(len(persons)):
if i == 0:
print('%s在面试' % persons[0])
else:
print('%s叫%s去面试' % (name, persons[i]))
print('%s面试结束' % persons[i])
name = yield persons[i]


obj = order(persons)
for i in range(len(persons)):
if i == 0:
p = obj.__next__()
else:
p = obj.send(p)
print('---------------')

递归:

函数直接或间接调用本身,都称之为递归

回溯:找寻答案的过程

递推:推出结果的过程

前提条件:

1.递归必须有出口

2.递归回溯递推的条件一定有规律

案例:

 

# 比如总共有5个人,询问第一个人的年纪,他说我比第二个人大两岁,问第二个人他说
# 我比第三个人大两岁,依次类推。直到第五个人他说他40岁,求第一个人的年纪
def get_age(count): # 获取人的数量,count是外界传入的信息,告诉它是几个人
if count == 1: # 这里是出口,给出最后一个人的年纪
return 40 # 最后一个人的年纪,来通过减法来反推
age = get_age(count - 1)-2 # 每次进来都回把人数减1,并且岁数减2.直到count = 1 .得到最后一个人的年纪
return age # 然后返回 计算出的第一个人的年纪
age = get_age(10)
print(age) # 结果为22岁


# 求 n 的阶乘, 比如5的阶乘= 5!* 4!* 3!* 2!* 1! = 120
# 5! = 5 * 4
# 4! = 4 * 3
# 3! = 3 * 2
# 2! = 2 * 1
# 1! = 1 # 数学界规定,1的阶乘等于1
def jiecheng(n):
if n ==1 or n ==0:
return 1
ji = n * jiecheng(n-1)
return ji
res = jiecheng(5)
print(res) # 结果为120

 

匿名函数

1.函数没有函数体,

2.匿名函数的关键字采用 lambda

3.关键字 lambda 与 标识函数功能体: 之间一定是参数,所以省略()

4.匿名还是没有函数体,只有返回值,所以函数体和返回值的return关键字都省略了

 

格式:  lambda *args,**kwargs:'返回值'

 

注意:

1.参数的使用和有名函数一样,六种形参都支持

2.返回值必须明确成一个值,可以为单个值对象,也可以为一个容器对象

 

max结合匿名工作原理

1.max内部会遍历iter, 将遍历结果逐一传给lambda的参数x

2.依据lambda的返回值作为比较条件,得到最大条件下的哪个遍历值

3.对外返回最大的遍历值

 

常用的内置函数

map()函数

# res = map(lambda x:x * 2,[3,1,2])  # 将遍历结果映射为任意类型值,
# print(list(res)) # 此处使用list接收
# print(tuple(res)) # 也可以使用元祖接收


#  reduce() 函数会对参数序列中元素进行累积。
# from functools import reduce
# res = reduce(lambda x, y: x * y, [3, 1, 2]) # 使用匿名函数,来计算列表中所有数字相乘的结果
# print(res) # 结果为6

 

上一篇:7. 列表渲染


下一篇:SQL Alias(别名)