递归 | Python从入门到精通:高阶篇之十一

点击查看上一节:命名空间

递归

首先来看一个例子:求一个数字的阶乘。
什么是阶乘?

用数字说明:
1! = 1
2! = 1*2 = 2
3! = 1*2*3 = 6
4! = 1*2*3*4 = 24

接下来联系一个例子,10!。
1、直接相乘

#最笨的方法,老老实实的从1相乘到10
print(1*2*3*4*5*6*7*8*9*10)

但是这个显然是不方便的,如果是求到100!,1000!。。。呢?

2、用循环求阶乘

# 创建一个变量保存结果
n = 10
for i in range(1,10):
    n *= i
print(n)

结果为:
递归 | Python从入门到精通:高阶篇之十一
显然也是正确的。

3、创建一个函数,可以用来求任意数的阶乘
语法结构:

参数:

        n 为要求阶乘的数字

代码显示:

def factorial(n):
    # 创建一个变量,来保存结果
    result = n
    
    for i in range(1,n):
        result *= i

    return result    
# 求10的阶乘    
print(factorial(10)) #调用函数即可,并赋予一个参数

执行结果为:
递归 | Python从入门到精通:高阶篇之十一
而且此时只需要修改需要求阶乘的数字即可,就会调用函数来求不同数字的阶乘了。

递归的概念

递归就是一个递归式的函数,而且递归不是Python独有的,其他语言里面也会有。

小故事:
从前有座山,山里有座庙,庙里有个老和尚讲故事,讲的什么故事呢?
从前有座山,山里有座庙,庙里有个老和尚讲故事,讲的什么故事呢?....
这个故事就可以无限的循环下去了。。这就是递归的一种形式。

那么递归简单理解就是自己去引用自己!
递归式函数,就是在函数中自己调用自己!
无穷递归:如果这个函数被调用,程序的内存会溢出,效果类似于死循环。如下展示:

def fn():
    fn()
fn()

会造成系统的崩溃,不要随便写这种函数。

概念

递归是解决问题的一种方式,它和循环很像,它的整体思想是,将一个大问题分解为一个个的小问题,直到问题无法分解时,再去解决问题。

递归式函数的两个要件

1.基线条件:问题可以被分解为的最小问题,当满足基线条件时,递归就不在执行了
2.递归条件:将问题继续分解的条件

递归和循环

用10!来展示一下递归:

10! = 10 * 9!
9! = 9 * 8!
8! = 8 * 7!
 ...
1! = 1

递归的方式:

def factorial(n):
    # 基线条件 判断n是否为1,如果为1则此时不能再继续递归
    if n == 1 :
        # 1的阶乘就是1,直接返回1
        return 1
    # 递归条件    
    return n * factorial(n-1)
print(factorial(10))

执行结果为:
递归 | Python从入门到精通:高阶篇之十一
之前的课程中我们也讲过循环的写法,两者基本是类似的,可以互相替换,但是循环编写起来比较容易,阅读起来稍难;递归编写起来难,但是方便阅读。

练习
1、创建一个函数 power 来为任意数字做幂运算 n ** i
2、创建一个函数,用来检查一个任意的字符串是否是回文字符串,如果是返回True,否则返回False。
回文字符串,字符串从前往后念和从后往前念是一样的。

点击学习配套视频课程

获取更多内容请订阅Python学习站官方技术圈!

上一篇:参数传递的方式 | Python从入门到精通:高阶篇之三


下一篇:递归的练习课程 | Python从入门到精通:高阶篇之十二