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使用socket远程连接错误处理方法
Apr 29 Python
用Python编写生成树状结构的文件目录的脚本的教程
May 04 Python
使用Python3编写抓取网页和只抓网页图片的脚本
Aug 20 Python
Windows系统下使用flup搭建Nginx和Python环境的方法
Dec 25 Python
python出现&quot;IndentationError: unexpected indent&quot;错误解决办法
Oct 15 Python
python音频处理用到的操作的示例代码
Oct 27 Python
在python3.5中使用OpenCV的实例讲解
Apr 02 Python
使用python3实现操作串口详解
Jan 01 Python
python3实现高效的端口扫描
Aug 31 Python
django框架cookie和session用法实例详解
Dec 10 Python
PyCharm使用Docker镜像搭建Python开发环境
Dec 26 Python
Python insert() / append() 用法 Leetcode实战演示
Mar 31 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中检查PHP文件是否有语法错误的方法
2009/12/23 PHP
php数组声明、遍历、数组全局变量使用小结
2013/06/05 PHP
php获取json数据所有的节点路径
2015/05/17 PHP
laravel5.4利用163邮箱发送邮件的步骤详解
2017/09/22 PHP
php中yii框架实例用法
2020/12/22 PHP
鼠标图片振动代码
2006/07/06 Javascript
理解Javascript_07_理解instanceof实现原理
2010/10/15 Javascript
js模拟select下拉菜单控件的代码
2013/05/08 Javascript
JQuery页面图片切换和新闻列表滚动效果的具体实现
2013/09/26 Javascript
jquery制作居中遮罩层效果分享
2014/02/21 Javascript
推荐5 个常用的JavaScript调试技巧
2015/01/08 Javascript
JS实现的表格操作类详解(添加,删除,排序,上移,下移)
2015/12/22 Javascript
jQuery弹出层后禁用底部滚动条(移动端关闭回到原位置)
2016/08/29 Javascript
实例分析浏览器中“JavaScript解析器”的工作原理
2016/12/12 Javascript
微信小程序商城项目之淘宝分类入口(2)
2017/04/17 Javascript
纯JS实现只能输入数字的简单代码
2017/06/21 Javascript
基于zepto.js实现登录界面
2017/10/09 Javascript
原生js实现仿window10系统日历效果的实例
2017/10/31 Javascript
Vue文件配置全局变量的实例
2018/09/06 Javascript
Vue开发之watch监听数组、对象、变量操作分析
2019/04/25 Javascript
JS实现简易留言板特效
2019/12/23 Javascript
Vue实现附件上传功能
2020/05/28 Javascript
Python连接mssql数据库编码问题解决方法
2015/01/01 Python
python路径的写法及目录的获取方式
2019/12/26 Python
python中lower函数实现方法及用法讲解
2020/12/23 Python
htnl5利用svg页面高斯模糊的方法
2018/07/20 HTML / CSS
梵蒂冈和罗马卡:Omnia Card Pass
2018/02/10 全球购物
牵手50新加坡:专为黄金岁月的单身人士而设的交友网站
2020/08/16 全球购物
程序运行正确, 但退出时却"core dump"了,怎么回事
2014/02/19 面试题
预备党员入党思想汇报
2014/01/04 职场文书
创先争优标语
2014/06/27 职场文书
农村门前三包责任书
2014/07/25 职场文书
弘扬焦裕禄精神走群众路线思想汇报
2014/09/12 职场文书
购房公证委托书(2014版)
2014/09/12 职场文书
助学金感谢信
2015/01/20 职场文书
ubuntu开机后ROS程序自启动问题
2022/12/24 Servers