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 defcalc(n):2 print(n)3 if n/2 > 1:4 res = calc(n/2)5 returnn6 calc(8)

结果为:

1 8

2 4.0

3 2.0

再看这一个示例:

1 defcalc(n):2 print(n)3 if n/2 > 1:4 res = calc(n/2)5 print('res:',res)6 print("N:",n)7 returnn8 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 deffunc():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 deffunc():2 print('11111111')3 yield [1]4 print(2222222222)5 yield 2

6 print(3333333333)7 yield 3

8 ret=func()9 for i inret:10 print(i)

结果同前面相同。

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

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

1 def counter(start_at=0):2   count =start_at3   whileTrue:4     val = (yield count) if val is notNone:5     count =val6   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 "", line 1, in

14 StopIteration

Python 的详细介绍:请点这里

Python 的下载地址:请点这里

logo.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值