递归 | 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)

结果为:
image.png
显然也是正确的。

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

参数:

        n 为要求阶乘的数字

代码显示:

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

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

执行结果为:
image.png
而且此时只需要修改需要求阶乘的数字即可,就会调用函数来求不同数字的阶乘了。

递归的概念

递归就是一个递归式的函数,而且递归不是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))

执行结果为:
image.png
之前的课程中我们也讲过循环的写法,两者基本是类似的,可以互相替换,但是循环编写起来比较容易,阅读起来稍难;递归编写起来难,但是方便阅读。

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

点击学习配套视频课程

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

相关文章
|
4天前
|
存储 程序员 API
Python 入门指南(五)(4)
Python 入门指南(五)
12 1
|
1天前
|
网络协议 网络架构 Python
Python 网络编程基础:套接字(Sockets)入门与实践
【5月更文挑战第18天】Python网络编程中的套接字是程序间通信的基础,分为TCP和UDP。TCP套接字涉及创建服务器套接字、绑定地址和端口、监听、接受连接及数据交换。UDP套接字则无连接状态。示例展示了TCP服务器和客户端如何使用套接字通信。注意选择唯一地址和端口,处理异常以确保健壮性。学习套接字可为构建网络应用打下基础。
18 7
|
2天前
|
Python
10个python入门小游戏,零基础打通关,就能掌握编程基础_python编写的入门简单小游戏
10个python入门小游戏,零基础打通关,就能掌握编程基础_python编写的入门简单小游戏
|
4天前
|
Python 索引 C语言
Python3从零基础到入门(2)—— 运算符-3
Python3从零基础到入门(2)—— 运算符
|
4天前
|
Python
Python3从零基础到入门(2)—— 运算符-2
Python3从零基础到入门(2)—— 运算符
Python3从零基础到入门(2)—— 运算符-2
|
4天前
|
Python C语言 存储
Python3从零基础到入门(2)—— 运算符-1
Python3从零基础到入门(2)—— 运算符
Python3从零基础到入门(2)—— 运算符-1
|
4天前
|
存储 C语言 Python
|
4天前
|
Python Windows
|
4天前
|
NoSQL 测试技术 API
Python 入门指南(七)(4)
Python 入门指南(七)
9 0
|
4天前
|
测试技术 程序员 数据库
Python 入门指南(七)(3)
Python 入门指南(七)
7 0