【Python】代码复用与函数递归

简介: 【Python】代码复用与函数递归

【Python】代码复用与函数递归

把代码当成一种资源,

代码资源化:程序代码是一种用来表达计算的资源;

代码抽象化:使用函数等方法对代码赋予更高级别的定义;

代码复用:同一份代码在需要时可以被重复使用。

       函数和对象是代码复用的两种表现形式,函数将代码命名,在代码层面建立了初步的抽象。


模块化设计:通过函数或对象封装将程序划分为模块及模块间的表达。具体包括:主程序,子程序和子程序之间的关系。

紧耦合:两个部分之间的交流很多,无法独立存在;

松耦合:两个部分之间交流较少,可以独立存在。

       模块内部紧耦合,模块之间松耦合。

函数递归

       函数递归不仅仅在程序中,数学中也学习过,递归中有两个关键的特征:链条和基例。

基例就是最基础的那个条件;

链条是n和n-1之间满足的条件。


数学归纳法

证明当n取第一个值n(0)时命题成立,

假设当n(k)时命题成立,证明当n=n(k+1)命题也成立,

递归是数学归纳法思维的编程体验。

看下例子:

image.png

看代码:

image.png

       递归本身就是一个函数,需要用函数定义方式描述,函数内部需要区分哪些是基例哪些是链条,基例和链条分别对应代码。

n=5,fact(5)=5*fact(4)

这时计算机会分配内存去计算fact(4)

然后一直往下 fact(3) 、fact(2)、 fact(1)

fact(1)=1*fact(0)

fact(0)=1

然后结果不断的返回 得到fact(5)。

       根据函数的定义,我们可以把定义理解为模板。计算机在进行运算时,会对模板进行循环往复的运算。


函数递归实例解析

       字符串的反转,将字符串S反转后输出,之前学习过字符串的切片,s[::-1]可以实现字符串的反转。意思是采用-1的步长进行输出。看递归的实现,函数+分支结构,区分递归链条和递归基例。

image.png

很简单吧,再看一个例子,斐波那契数列

F(1)=1

F(2)=1

F(3)=F(1)+F(2)

F(n)=F(n-1)+F(n-2)

看程序:

image.png

       再看一个稍微复杂的实例,汉诺塔问题 。汉诺塔指的是。。。(槽,自己去搜)。

       A B C 代表三个柱子   汉诺塔默认在A柱子上。

image.png

从A搬到C,小圆盘一直在大圆盘上面。

image.png

       n代表层数,上面是四层汉诺塔的解决问题。scr是源柱子,dst是目标柱子,mid是中间柱子。

目录
相关文章
|
4月前
|
存储 缓存 测试技术
Python中的装饰器:功能增强与代码复用的利器
在Python编程中,装饰器是一种强大而灵活的工具,它允许开发者以简洁优雅的方式增强函数或方法的功能。本文将深入探讨装饰器的定义、工作原理、应用场景以及如何自定义装饰器。通过实例演示,我们将展示装饰器如何在不修改原有代码的基础上添加新的行为,从而提高代码的可读性、可维护性和复用性。此外,我们还将讨论装饰器在实际应用中的一些最佳实践和潜在陷阱。
|
1月前
|
开发者 Python
Python入门:8.Python中的函数
### 引言 在编写程序时,函数是一种强大的工具。它们可以将代码逻辑模块化,减少重复代码的编写,并提高程序的可读性和可维护性。无论是初学者还是资深开发者,深入理解函数的使用和设计都是编写高质量代码的基础。本文将从基础概念开始,逐步讲解 Python 中的函数及其高级特性。
Python入门:8.Python中的函数
|
27天前
|
C语言 Python
Python学习:内建属性、内建函数的教程
本文介绍了Python中的内建属性和内建函数。内建属性包括`__init__`、`__new__`、`__class__`等,通过`dir()`函数可以查看类的所有内建属性。内建函数如`range`、`map`、`filter`、`reduce`和`sorted`等,分别用于生成序列、映射操作、过滤操作、累积计算和排序。其中,`reduce`在Python 3中需从`functools`模块导入。示例代码展示了这些特性和函数的具体用法及注意事项。
|
27天前
|
Go Python
Python中的round函数详解及使用示例
`round()`函数是Python内置的用于四舍五入数字的工具。它接受一个数字(必需)和可选的小数位数参数,返回最接近的整数或指定精度的浮点数。本文详细介绍其用法、参数及示例,涵盖基本操作、负数处理、特殊情况及应用建议,帮助你更好地理解和运用该函数。
|
1月前
|
人工智能 数据库连接 开发工具
[oeasy]python069_当前作用域都有些什么_列表dir_函数_builtins
本文介绍了Python中`dir()`函数的使用方法及其作用。`dir()`可以列出当前作用域内的所有变量和成员,类似于`locals()`,但`dir()`不仅限于本地变量,还能显示模块中的所有成员。通过`dir(__builtins__)`可以查看内建模块中的所有内建函数,如`print`、`ord`、`chr`等。此外,还回顾了`try-except-finally`结构在数据库连接中的应用,并解释了为何`print`函数可以直接使用而无需导入,因为它位于`__builtins__`模块中。最后,简要提及了删除`__builtins__.print`的方法及其影响。
35 0
|
4月前
|
搜索推荐 Python
利用Python内置函数实现的冒泡排序算法
在上述代码中,`bubble_sort` 函数接受一个列表 `arr` 作为输入。通过两层循环,外层循环控制排序的轮数,内层循环用于比较相邻的元素并进行交换。如果前一个元素大于后一个元素,就将它们交换位置。
165 67
|
2月前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
43 3
|
2月前
|
JSON 监控 安全
深入理解 Python 的 eval() 函数与空全局字典 {}
`eval()` 函数在 Python 中能将字符串解析为代码并执行,但伴随安全风险,尤其在处理不受信任的输入时。传递空全局字典 {} 可限制其访问内置对象,但仍存隐患。建议通过限制函数和变量、使用沙箱环境、避免复杂表达式、验证输入等提高安全性。更推荐使用 `ast.literal_eval()`、自定义解析器或 JSON 解析等替代方案,以确保代码安全性和可靠性。
73 2
|
2月前
|
存储 人工智能 Python
[oeasy]python061_如何接收输入_input函数_字符串_str_容器_ 输入输出
本文介绍了Python中如何使用`input()`函数接收用户输入。`input()`函数可以从标准输入流获取字符串,并将其赋值给变量。通过键盘输入的值可以实时赋予变量,实现动态输入。为了更好地理解其用法,文中通过实例演示了如何接收用户输入并存储在变量中,还介绍了`input()`函数的参数`prompt`,用于提供输入提示信息。最后总结了`input()`函数的核心功能及其应用场景。更多内容可参考蓝桥、GitHub和Gitee上的相关教程。
36 0
|
3月前
|
Python
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
91 18