python函数递归和生成器

简介: python函数递归和生成器

一、什么是递归

如果函数包含了对其自身的调用,该函数就是递归的。递归做为一种算法在程序设计语言中广泛应用,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。例如,要计算1-9的9位数字的乘积,直观的算法是1*2*3*4*5*6*7*8*9,如果要计算1-10000的乘积,直观的算法就难于实现出,而递归就可以很简单的实现。请看示例:

1 def fact(n):#计算给定数字到一的乘积
2     if n<=1:
3         return 1
4     else:
5         return n * fact(n-1)  
6 print (fact(7))
结果为:5040

下面我们用示例来看看递归的执行过程:

1 def calc(n):
2     print(n)
3     if n/2 > 1:
4         res = calc(n/2)
5     return n
6 calc(8)

结果为:

1 8
2 4.0
3 2.0

再看这一个示例:

1 def calc(n):
2     print(n)
3     if n/2 > 1:
4         res = calc(n/2)
5         print('res:',res)
6     print("N:",n)
7     return n
8 calc(8)

结果为:

1 8
2 4.0
3 2.0
4 N: 2.0
5 res: 2.0
6 N: 4.0
7 res: 4.0
8 N: 8

二、生成器

生成器是一个带 yield 语句的函数。一个函数或者子 程序只返回一次,但一个生成器能暂停执行并返回一个中间的结果,返 回一个值给调用者并暂停执行。当生成器的 next()方法被调用的时候,它会准确地从离开地方继续

下面看示例:

1 def func():
 2     print('11111111')
 3     yield [1]
 4     print(2222222222)
 5     yield 2
 6     print(3333333333)
 7     yield 3
 8
 9 ret=func()
10 r1=ret.__next__()
11 print(r1)
12 r2=ret.__next__()
13 print(r2)
14 r3=ret.__next__()
15 print(r3)

结果为:

1 11111111
2 13 2222222222
4 2
5 3333333333
6 3

由于 python 的 for 循环有 next()调用和对 StopIteration 的处理, 使用一个 for 循环而不是手 动迭代穿过一个生成器(或者那种事物的迭代器)总是要简洁漂亮得多。例:

1 def func():
 2     print('11111111')
 3     yield [1]
 4     print(2222222222)
 5     yield 2
 6     print(3333333333)
 7     yield 3
 8 ret=func()
 9 for i in ret:
10     print(i)

结果同前面相同。

这些简单的例子应该让你有点明白生成器是如何工作的。除了 next()来获得下个生成的值,用户 可以将值回送给生成器[send()],在生成器中抛出异常,以及要求生成器退出[close()]

下面是一个展示了这些特性的,简单的例子。

1 def counter(start_at=0):
2   count = start_at
3   while True:
4     val = (yield count) if val is not None:
5     count = val
6   else:
7     count += 1

生成器带有一个初始化的值,对每次对生成器[next()]调用以 1 累加计数。用户已可以选择重 置这个值,如果他们非常想要用新的值来调用 send()不是调用 next()。这个生成器是永远运行的,所以如果你想要终结它,调用 close()方法。如果我们交互的运行这段代码,会得到如下输出:

1 >>> count = counter(5)
 2 >>> count.next()
 3 5
 4 >>> count.next()
 5 6
 6 >>> count.send(9)
 7 9
 8 >>> count.next()
 9 10
10 >>> count.close()
11 >>> count.next()
12 Traceback (most recent call last):
13 File "<stdin>", line 1, in <module>
14 StopIteration
相关文章
|
17天前
|
开发者 Python 容器
python函数基础以及函数参数简解
python函数基础以及函数参数简解
|
10天前
|
Python
python 函数
【9月更文挑战第4天】python 函数
33 5
WK
|
17天前
|
Python
python中的函数有哪些种类?
在 Python 中,函数根据定义方式、用途及来源可分为多种类型:自带的内置函数(如 print(), len())无需导入直接使用;标准库函数需导入相应模块后使用;第三方库函数则需先安装库再导入使用;用户自定义函数可根据需求定义并多次调用;匿名函数(lambda)无函数名,常用于需要函数对象但不想单独定义的情形;高阶函数接受或返回函数;装饰器函数可在不改动原函数代码情况下为其添加新功能;生成器函数使用 yield 逐个返回值;递归函数在自身定义中调用自身;嵌套函数在一个函数内定义,可访问外部函数变量。各种函数类型在编程中有不同的用途和优势。
WK
38 12
|
16天前
|
Python
Python 中 help() 和 dir() 函数的用法
【8月更文挑战第29天】
18 5
|
17天前
|
Python
12类常用的Python函数
12类常用的Python函数
|
18天前
|
算法 搜索推荐 数据处理
|
17天前
|
Python
python中getattr函数 hasattr函数
python中getattr函数 hasattr函数
|
16天前
|
Python
Python eval()函数的使用
Python eval()函数的使用
15 1
|
17天前
|
Python
python常用内置函数
python常用内置函数
|
18天前
|
分布式计算 索引 Python
8个超好用的Python内置函数,提升效率必备!
8个超好用的Python内置函数,提升效率必备!