python函数递归和生成器

Posted Mr. Pan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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 [1]
3 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

 

以上是关于python函数递归和生成器的主要内容,如果未能解决你的问题,请参考以下文章

python学习week5-递归,匿名函数生成器

Python 是不是具有用于一阶递归关系的迭代递归生成器函数?

Python 生成器 匿名函数 递归 模块及包的导入 正则re

递归函数生成器装饰器

python--递归函数匿名函数嵌套函数高阶函数装饰器生成器迭代器

python协程函数递归匿名函数与内置函数使用模块与包