python利用高阶函数实现剪枝函数
作者:北门吹雪 时间:2022-04-17 11:21:44
本文为大家分享了python利用高阶函数实现剪枝函数的具体代码,供大家参考,具体内容如下
案例:
某些时候,我们想要为多个函数,添加某种功能,比如计时统计,记录日志,缓存运算结果等等
需求:
在每个函数中不需要添加完全相同的代码
如何解决?
把相同的代码抽调出来,定义成装饰器
求斐波那契数列(黄金分割数列),从数列的第3项开始,每一项都等于前两项之和
求一个共有10个台阶的楼梯,从下走到上面,一次只能迈出1~3个台阶,并且不能后退,有多少中方法?
上台阶问题逻辑整理:
每次迈出都是 1~3 个台阶,剩下就是 7~9 个台阶
如果迈出1个台阶,需要求出后面9个台阶的走法
如果迈出2个台阶,需要求出后面8个台阶的走法
如果迈出3个台阶,需要求出后面7个台阶的走法
此3种方式走法,通过递归方式实现,递归像树,每次递归都生成子节点函数
以上两个问题通过递归来解决,就会出现一个问题,出现重复求解问题,把重复求解的过程剔除掉,在c++语言中称为剪枝函数
#!/usr/bin/python3
def jian_zhi(func):
# 中间字典,判断已经是否求解过
median = {}
def wrap(*args):
# 假如不在中间字典中,说明没有求解过,添加到字典中去,在的话,直接返回
if args not in median:
median[args] = func(*args)
return median[args]
return wrap
@jian_zhi
def fibonacci(n):
if n <= 1:
return 1
return fibonacci(n-1) + fibonacci(n-2)
@jian_zhi
def climb(n, steps):
count = 0
# 当最后台阶为0的时候,说明最后只是走了一次
if n == 0:
count = 1
# 当最后台阶不为0的时候,说明还需要走至少一次
elif n > 0:
# 对三种情况进行分别处理momo
for step in steps:
count += climb(n-step, steps)
# 返回每次递归的计数
return count
if __name__ == '__main__':
print(climb(10, (1, 2, 3)))
print(fibonacci(20))
所谓的剪枝函数不过是保证每次递归的函数唯一性,利用中间字典保存已经执行过得函数和参数,通过判断参数,剔除重复的函数调用
来源:http://www.cnblogs.com/2bjiujiu/p/7291032.html
标签:python,高阶函数,剪枝函数
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python打包成so文件过程解析
2022-03-19 18:08:46
pytorch 实现查看网络中的参数
2023-10-28 22:08:37
Python 中Operator模块的使用
2021-04-02 05:30:34
![](https://img.aspxhome.com/file/2023/5/83845_0s.png)
浅谈java里的EL表达式在JSP中不能解析的问题
2023-06-20 11:55:05
Python unittest单元测试openpyxl实现过程解析
2023-06-17 10:54:31
![](https://img.aspxhome.com/file/2023/2/103482_0s.jpg)
Python 可视化神器Plotly详解
2022-02-18 04:25:37
![](https://img.aspxhome.com/file/2023/1/95421_0s.jpg)
在pandas中遍历DataFrame行的实现方法
2022-02-16 13:13:26
![](https://img.aspxhome.com/file/2023/7/75867_0s.jpg)
python 爬取疫情数据的源码
2022-05-22 13:21:54
![](https://img.aspxhome.com/file/2023/1/66831_0s.jpg)
使用Python开发游戏运行脚本成功调用大漠插件
2021-03-09 21:05:53
![](https://img.aspxhome.com/file/2023/9/99679_0s.png)
Python 3 使用Pillow生成漂亮的分形树图片
2022-05-03 14:53:23
![](https://img.aspxhome.com/file/2023/2/109962_0s.jpg)
python快速排序的实现及运行时间比较
2022-11-30 20:41:27
![](https://img.aspxhome.com/file/2023/3/90523_0s.png)
Python爬虫实战之用selenium爬取某旅游网站
2021-03-25 10:28:36
![](https://img.aspxhome.com/file/2023/4/72724_0s.png)
python实现SOM算法
2023-05-27 03:18:42
![](https://img.aspxhome.com/file/2023/8/117598_0s.png)
pandas数据清洗(缺失值和重复值的处理)
2021-10-05 10:36:43
![](https://img.aspxhome.com/file/2023/7/92307_0s.png)
php实现的支持断点续传的文件下载类
2023-11-23 16:52:19
运行tensorflow python程序,限制对GPU和CPU的占用操作
2022-07-03 02:49:26
将pytorch的网络等转移到cuda
2023-08-10 08:33:46
Django 批量插入数据的实现方法
2023-01-11 10:40:58
如何在事件代理中正确使用 focus 和 blur 事件
2010-01-30 12:51:00
ASP小偷(远程数据获取)程序的入门教程
2007-09-21 12:48:00