位置: 编程技术 - 正文

python装饰器与递归算法详解

编辑:rootadmin

推荐整理分享python装饰器与递归算法详解,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

1、python装饰器

刚刚接触python的装饰器,简直懵逼了,直接不懂什么意思啊有木有,自己都忘了走了多少遍Debug,查了多少遍资料,猜有点点开始明白了。总结了一下解释得比较好的,通俗易懂的来说明一下:

小P闲来无事,随便翻看自己以前写的一些函数,忽然对一个最最最基础的函数起了兴趣:

此时小P想看看这个函数执行用了多长时间,所以写了几句代码插进去了:

运行之后,完美~~

可是随着继续翻看,小P对越来越多的函数感兴趣了,都想看下他们的运行时间如何,难道要一个一个的去改函数吗?当然不是!我们可以考虑重新定义一个函数timeit,将sum1的引用传递给他,然后在timeit中调用sum1并进行计时,这样,我们就达到了不改动sum1定义的目的,而且,不论小P看了多少个函数,我们都不用去修改函数定义了!

咂一看,没啥问题,可以运行!但是还是修改了一部分代码,把sum1() 改成了timeit(sum1)。这样的话,如果sum1在N处都被调用了,你就不得不去修改这N处的代码。所以,我们就需要杨sum1()具有和timeit(sum1)一样的效果,于是将timeit赋值给sum1。可是timeit是有参数的,所以需要找个方法去统一参数,将timeit(sum1)的返回值(计算运行时间的函数)赋值给sum1。

这样一个简易的装饰器就做好了,我们只需要在定义sum1以后调用sum1之前,加上sum1= timeit(sum1),就可以达到计时的目的,这也就是装饰器的概念,看起来像是sum1被timeit装饰了!Python于是提供了一个语法糖来降低字符输入量。

python装饰器与递归算法详解

重点关注第行的@timeit,在定义上加上这一行与另外写sum1 = timeit(sum1)完全等价。

2、递归算法

递归算法是一种直接或者间接地调用自身算法的过程。在计算机编写程序中,递归算法对解决一大类问题是十分有效的,它往往使算法的描述简洁而且易于理解。

递归算法解决问题的特点:

(1) 递归就是在过程或函数里调用自身。(2) 在使用递归策略时,必须有一个明确的递归结束条件,称为递归出口。(3) 递归算法解题通常显得很简洁,但递归算法解题的运行效率较低。所以一般不提倡用递归算法设计程序。(4) 在递归调用的过程当中系统为每一层的返回点、局部量等开辟了栈来存储。递归次数过多容易造成栈溢出等。所以一般不提倡用递归算法设计程序。

举个栗子:对一个数字进行除2求值,直到小于等于1时退出并输出结果

结果说明(不return时相当于嵌套循环,一层层进入在一层层退出):

2、递归时return:

结果说明(return时就直接结束本次操作):

用递归实现斐波那契函数

使用Python来编写HTTP服务器的超级指南 首先,到底什么是网络服务器?简而言之,它是在物理服务器上搭建的一个网络连接服务器(networkingserver),永久地等待客户端发送请求。当服务器收

使用Python的PIL模块来进行图片对比 在使用google或者baidu搜图的时候会发现有一个图片颜色选项,感觉非常有意思,有人可能会想这肯定是人为的去划分的,呵呵,有这种可能,但是估计人

讲解Python的Scrapy爬虫框架使用代理进行采集的方法 1.在Scrapy工程下新建middlewares.py#Importingbaselibrarybecausewe'llneeditONLYincaseiftheproxywearegoingtouserequiresauthenticationimportbase#StartyourmiddlewareclassclassProxyMiddleware(obje

标签: python装饰器与递归算法详解

本文链接地址:https://www.jiuchutong.com/biancheng/382368.html 转载请保留说明!

上一篇:Python利用Nagios增加微信报警通知的功能(python import os)

下一篇:使用Python来编写HTTP服务器的超级指南(python编写步骤)

  • 销项税减去进项税
  • 企业留存的盈余公积属于哪个会计科目
  • 12月工资1月发个税怎么算
  • 长期待摊费用可以转入固定资产吗
  • 已导出的申报表如何修改
  • 企业滞留发票的产生和处理
  • 地下车库的成本核算
  • 税务局返还的个税手续费税率
  • 承包工程会计账务处理流程
  • 农产品收购发票是普票还是专票
  • 增值税视同销售包括哪些情况?
  • 现在地税发票还要交税吗
  • 每个行业都能赚钱吗
  • 转让股权应具备什么条件
  • 股权转让印花税税率是多少
  • 全年实现利润总额为6035
  • 信汇凭证是转账凭证吗
  • 计提福利费用会计分录
  • 零售不开票收入会计分录
  • 华为折叠手机mateXs
  • 更改代理设置失败 可能无网络连接
  • 纳税人外购下列已税消费品
  • 固定资产的折旧是什么意思
  • 非一般纳税人可以抵扣吗
  • 详谈php编码转换过程
  • php mysql pdo
  • amr文件什么意思
  • 个人所得税应该计入什么科目
  • 短期借款利息计算
  • 马耳他共和国瓦莱塔福利
  • 在途物资属于什么存货
  • react connect用法
  • 应收账款需要计提损失准备吗
  • php框架选择2021
  • php分层架构
  • 图像融合名词解释
  • 出口货物不退税进项可以开具普通发票吗
  • js栈堆的区别
  • php微信公众号消息推送
  • 广东高速公路过路费官网
  • 铁路运费的印花税进什么科目
  • 办公用品和低值易耗品节省成本吗
  • 增值税申报销项发票采集少了怎么办
  • SqlServer2014安装选择版本
  • 劳务派遣工资的发放单位
  • 影响无形资产的营业利润怎么算
  • 发行股票的账务处理
  • 怎么判断其他债权债务
  • 冲暂估的账务处理
  • 总结哪些纳税人可以采用简易计税方法
  • 财务费用手续费借贷方向
  • 会计核算健全的单位 可以选择小规模纳税的有
  • 本年利润的计算顺序为
  • 商品销售成本的计算方法中,商品零售企业
  • mysql 大数据处理
  • 安装office提示
  • 一台OpenSuSE系统的服务器的网络配置
  • macbookair numbers
  • mac快捷键一览
  • macbook做热点
  • jgcx是什么软件的文件
  • xp系统关机没反应怎么办
  • macpro防火墙需要打开吗
  • xp系统的cad
  • 如何修改windows默认语言
  • windows10预览版是什么
  • opengl怎么学
  • 获取文件内容
  • opengl arb
  • 人走鸟不惊,出自于谁的诗句?
  • js兼容ie
  • css fontstyle
  • unity碰撞抖动怎么解决
  • 红杏是什么意思什么样的
  • js如何禁用按钮
  • 如何缴纳地税工伤保险
  • 电子税务局的社保不能扣款怎么办
  • 河北地税代收工作怎么样
  • 深圳城管局 局长
  • 福州灵活就业社保缴费2024年多少钱
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设