递归 | 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学习站官方技术圈!

相关文章
|
2月前
|
存储 数据挖掘 开发者
Python编程入门:从零到英雄
在这篇文章中,我们将一起踏上Python编程的奇幻之旅。无论你是编程新手,还是希望拓展技能的开发者,本教程都将为你提供一条清晰的道路,引导你从基础语法走向实际应用。通过精心设计的代码示例和练习,你将学会如何用Python解决实际问题,并准备好迎接更复杂的编程挑战。让我们一起探索这个强大的语言,开启你的编程生涯吧!
|
26天前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
1月前
|
机器学习/深度学习 数据可视化 数据挖掘
使用Python进行数据分析的入门指南
本文将引导读者了解如何使用Python进行数据分析,从安装必要的库到执行基础的数据操作和可视化。通过本文的学习,你将能够开始自己的数据分析之旅,并掌握如何利用Python来揭示数据背后的故事。
|
2月前
|
机器学习/深度学习 数据可视化 数据挖掘
使用Python进行数据分析的入门指南
【10月更文挑战第42天】本文是一篇技术性文章,旨在为初学者提供一份关于如何使用Python进行数据分析的入门指南。我们将从安装必要的工具开始,然后逐步介绍如何导入数据、处理数据、进行数据可视化以及建立预测模型。本文的目标是帮助读者理解数据分析的基本步骤和方法,并通过实际的代码示例来加深理解。
60 3
|
2月前
|
JSON Linux 数据格式
Python模块:从入门到精通,只需一篇文章!
Python中的模块是将相关代码组织在一起的单元,便于重用和维护。模块可以是Python文件或C/C++扩展,Python标准库中包含大量模块,如os、sys、time等,用于执行各种任务。定义模块只需创建.py文件并编写代码,导入模块使用import语句。此外,Python还支持自定义模块和包,以及虚拟环境来管理项目依赖。
Python模块:从入门到精通,只需一篇文章!
|
27天前
|
IDE 程序员 开发工具
Python编程入门:打造你的第一个程序
迈出编程的第一步,就像在未知的海洋中航行。本文是你启航的指南针,带你了解Python这门语言的魅力所在,并手把手教你构建第一个属于自己的程序。从安装环境到编写代码,我们将一步步走过这段旅程。准备好了吗?让我们开始吧!
|
26天前
|
测试技术 开发者 Python
探索Python中的装饰器:从入门到实践
装饰器,在Python中是一块强大的语法糖,它允许我们在不修改原函数代码的情况下增加额外的功能。本文将通过简单易懂的语言和实例,带你一步步了解装饰器的基本概念、使用方法以及如何自定义装饰器。我们还将探讨装饰器在实战中的应用,让你能够在实际编程中灵活运用这一技术。
38 7
|
28天前
|
开发者 Python
Python中的装饰器:从入门到实践
本文将深入探讨Python的装饰器,这一强大工具允许开发者在不修改现有函数代码的情况下增加额外的功能。我们将通过实例学习如何创建和应用装饰器,并探索它们背后的原理和高级用法。
42 5
|
27天前
|
机器学习/深度学习 人工智能 算法
深度学习入门:用Python构建你的第一个神经网络
在人工智能的海洋中,深度学习是那艘能够带你远航的船。本文将作为你的航标,引导你搭建第一个神经网络模型,让你领略深度学习的魅力。通过简单直观的语言和实例,我们将一起探索隐藏在数据背后的模式,体验从零开始创造智能系统的快感。准备好了吗?让我们启航吧!
69 3
|
1月前
|
Python
Python编程入门:从零开始的代码旅程
本文是一篇针对Python编程初学者的入门指南,将介绍Python的基本语法、数据类型、控制结构以及函数等概念。文章旨在帮助读者快速掌握Python编程的基础知识,并能够编写简单的Python程序。通过本文的学习,读者将能够理解Python代码的基本结构和逻辑,为进一步深入学习打下坚实的基础。