python利用高阶函数实现剪枝函数


Posted in Python onMarch 20, 2018

本文为大家分享了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))

所谓的剪枝函数不过是保证每次递归的函数唯一性,利用中间字典保存已经执行过得函数和参数,通过判断参数,剔除重复的函数调用

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python Django模板的使用方法(图文)
Nov 04 Python
python检查字符串是否是正确ISBN的方法
Jul 11 Python
详解Python字符串对象的实现
Dec 24 Python
使用 Python 实现微信公众号粉丝迁移流程
Jan 03 Python
ubuntu 18.04搭建python环境(pycharm+anaconda)
Jun 14 Python
python如何以表格形式打印输出的方法示例
Jun 21 Python
python 有效的括号的实现代码示例
Nov 11 Python
Python 找出出现次数超过数组长度一半的元素实例
May 11 Python
PyTorch中的拷贝与就地操作详解
Dec 09 Python
python反编译教程之2048小游戏实例
Mar 03 Python
python实现腾讯滑块验证码识别
Apr 27 Python
教你用Python+selenium搭建自动化测试环境
Jun 18 Python
python flask中静态文件的管理方法
Mar 20 #Python
python web基础之加载静态文件实例
Mar 20 #Python
python如何修改装饰器中参数
Mar 20 #Python
python MySQLdb使用教程详解
Mar 20 #Python
django中的HTML控件及参数传递方法
Mar 20 #Python
安装python时MySQLdb报错的问题描述及解决方法
Mar 20 #Python
python如何定义带参数的装饰器
Mar 20 #Python
You might like
php校验表单检测字段是否为空的方法
2015/03/20 PHP
PHP自定义多进制的方法
2016/11/03 PHP
PHP实现的文件上传类与用法详解
2017/07/05 PHP
IE中直接运行显示当前网页中的图片 推荐
2006/08/31 Javascript
Javascript 调试利器 Firebug使用详解六
2009/07/05 Javascript
初学js 新节点的创建 删除 的步骤
2011/07/04 Javascript
固定表格行列(expression)在IE下适用
2013/07/25 Javascript
js 本地预览的简单实现方法
2014/02/18 Javascript
textarea焦点的用法实现获取焦点清空失去焦点提示效果
2014/05/19 Javascript
jQuery中is()方法用法实例
2015/01/06 Javascript
JS简单限制textarea内输入字符数量的方法
2015/10/14 Javascript
JavaScript lodash常见用法系列小结
2016/08/24 Javascript
利用Ionic2 + angular4实现一个地区选择组件
2017/07/27 Javascript
详解在vue-cli中引用jQuery、bootstrap以及使用sass、less编写css
2017/11/08 jQuery
vue中改变选中当前项的显示隐藏或者状态的实现方法
2018/02/08 Javascript
详解如何在vue项目中使用layui框架及采坑
2019/05/05 Javascript
使用layui实现树形结构的方法
2019/09/20 Javascript
使用JS来动态操作css的几种方法
2019/12/18 Javascript
python 实现归并排序算法
2012/06/05 Python
Python实现的Kmeans++算法实例
2014/04/26 Python
python文件特定行插入和替换实例详解
2017/07/12 Python
Python实现二维数组输出为图片
2018/04/03 Python
Python cookbook(字符串与文本)针对任意多的分隔符拆分字符串操作示例
2018/04/19 Python
Django添加sitemap的方法示例
2018/08/06 Python
python实现的登录与提交表单数据功能示例
2019/09/25 Python
python 中Arduino串口传输数据到电脑并保存至excel表格
2019/10/14 Python
python3光学字符识别模块tesserocr与pytesseract的使用详解
2020/02/26 Python
浅谈python处理json和redis hash的坑
2020/07/16 Python
哪些情况下不应该使用索引
2015/07/20 面试题
数控专业毕业生求职信范文
2013/09/21 职场文书
实习生个人的自我评价
2013/12/08 职场文书
《长城》教学反思
2014/02/14 职场文书
中式结婚主持词
2014/03/14 职场文书
优秀英文求职信范文
2015/03/19 职场文书
搞笑的婚礼主持词
2015/06/29 职场文书
2016年推广普通话宣传周活动总结
2016/04/06 职场文书