pyhthon --递归,装饰器
递归:
递归的概念很简单,如果函数包含了对其自身的调用,该函数就是递归。拗口一点的定义是,如果一个新的调用能在相同过程中较早的调用结束之前开始,那么该过程就是递归。
"""阶乘"""
def jie(n):
if n==0 or n==1:
return 1
else:
return n*jie(n-1)
print fac(8) D:\python3.5\python.exe D:/untitled/python2/denglu.py
40320 Process finished with exit code 0 '''''''''''递归方式‘'''''''''''''''''
def digui(n): #定义函数 循环后的结果
print(n) #输出每一次的结果
if n == 1: #如果不等于继续向下执行
return 1 #返回最终的结果
return digui(n-1) * 1 #返回的值减一在乘一
s = digui(10) #执行函数
print(s)
'''''''''''''''''斐波那契数列''''''''
斐波那契数列指的是这样一个数列 0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233,377,610,987,1597,2584,4181,6765,10946,17711,28657,46368 def digui(a,a1,a2): #定义函数,参数 #a = 2 a1= 13,a2 = 15 。。。。。。。。
if a == 10: #判断如果q不等于10 就向下执行
return a,a1,a2
a3 = a1 + a2 #两数相加附一个新值 a3 等于15
re = digui(a + 1,a2,a3) #继续回去一级一级循环结果 最终结果484
return re #定一个返回值 一级一级退出循环
z = digui(1,2,13) #执行函数的最终结果
print(z) D:\python3.5\python.exe D:/untitled/python2/denglu.py
(10, 484, 783) Process finished with exit code 0 def di(n,n1): #定义函数 参数 0,1
print(n) #输 出最终的结果
if n > 100: #如果n(0)大于100就向下继续执行直到大于100
return #返回终止
n2 = n + n1 # n=0 n1 = 1 n2 = 1
di(n1,n2) #两数相加继续循环
di(0,1) #执行函数 里的参数值 D:\python3.5\python.exe D:/untitled/python2/denglu.py
0
1
1
2
3
5
8
13
21
34
55
89
144
Process finished with exit code 0
def digui(q,q1):
print(q,q1)
if q == 10:
return
w = q2 = q + q1
return w
s = digui(34,324)
print(s) D:\python3.5\python.exe D:/untitled/python2/lianxi.py
34 324
358 Process finished with exit code 0
装饰器:
装饰器是函数,只不过该函数可以具有特殊的含义,装饰器用来装饰函数或类,使用装饰器可以在函数执行前和执行后添加相应操作。
def func(x):
print(x)
x =123 # 实参 x 代指123
func(x) 执行函数
嵌套一层的装饰器: def quan(yuan):#1 #定义装饰器函数, 这的参数代指的是原来(yuan1)函数
def xin(): #2 #4 装饰器的内置函数//// 被原函数重新赋值的
print('新的') #5 执行函数前的操作
ret = yuan() #6 执行原来的函数
print('后来的') #10 执行后的操作
return ret #11 原函数的返回值
return xin #3 返回的新函数的返回值
@quan #5 #7 自动应用执行装饰器的参数就是(yuan1)
def yuan1(): #原来的函数被重新赋值给了新的函数 定义为xin()
print('原来') #8 输出原来的值
return 'yes' #9 返回一个结果
s = yuan1() #执行函数结果
print(s) 嵌套两层的装饰器: def quan_0(gun): #原来的yuan 函数做了两次赋值 把quan函数调用成自己的内置函数
# 被quan_0代指 而这个gun参数等于quan内置函数里的gun参数
def xin(*args,**kwargs): #xin函数等于第二个装饰器的原来yuanl数重新第二次的赋值
print('123')
r = gun(*args,**kwargs)
return r
return xin
def quan(gun):
def xin(*args,**kwargs):
print("小伙")
r = gun(*args,**kwargs) #gun参数等于yuan函数里的参数
print('好')
return r
return xin
@quan_0
@quan
def yuan(q1,q2):
print('火了')
return q1 + q2
s = yuan(12,21)
print(s)
pyhthon --递归,装饰器的更多相关文章
- python递归,装饰器,函数, 高阶函数
在函数内部,可以调用其它函数,如果一个函数在内部调用自身本身,这个函数就是递归函数 递归特性:1.必须有一个明确的结束条件 2.每次进入更深一层递归时,问题规模比上次递归都有所减少(10-8-5等) ...
- python --> 递归 以及装饰器
一.递归知识 函数迭套执行,逐层执行之后,满足某个条件之后就会停止执行,将return值返回上层的函数,上层函数再逐层返回,最终返回给最初始函数. 递归在斐波那契数列的应用[斐波那契数列特点:前两个数 ...
- python学习笔记之装饰器、递归、算法(第四天)
参考老师的博客: 金角:http://www.cnblogs.com/alex3714/articles/5161349.html 银角:http://www.cnblogs.com/wupeiqi/ ...
- 学习PYTHON之路, DAY 5 - PYTHON 基础 5 (装饰器,字符格式化,递归,迭代器,生成器)
---恢复内容开始--- 一 装饰器 1 单层装饰器 def outer(func): def inner(): print('long') func() print('after') return ...
- python-学习笔记之-Day5 双层装饰器 字符串格式化 python模块 递归 生成器 迭代器 序列化
1.双层装饰器 #!/usr/bin/env python # -*- coding: utf-8 -*- # author:zml LOGIN_INFO = False IS_ADMIN = Fal ...
- python_way ,day5 模块,模块3 ,双层装饰器,字符串格式化,生成器,递归,模块倒入,第三方模块倒入,序列化反序列化,日志处理
python_way.day5 1.模块3 time,datetime, json,pickle 2.双层装饰器 3.字符串格式化 4.生成器 5.递归 6.模块倒入 7.第三方模块倒入 8.序列化反 ...
- Python(迭代器 生成器 装饰器 递归 斐波那契数列)
1.迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大优 ...
- Day5 双层装饰器、字符串格式化、生成器、迭代器、递归
双层装饰器实现用户登录和权限认证 #!/usr/bin/env python# -*- coding: utf-8 -*-# Author: WangHuafeng USER_INFO = {} de ...
- Python学习笔记 (4) :迭代器、生成器、装饰器、递归、正则表达式等
迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大优点是 ...
随机推荐
- XML操作类
using System; using System.Data; using System.IO; using System.Xml; namespace DotNet.Utilities { ...
- 关于webpack.optimize.CommonsChunkPlugin的使用二
Note:当有多个入口节点的时候,只有所有入口节点都引入了同一个模块的时候,webpack.optimize.CommonsChunkPlugin才会将那个模块提取出来,如果其中一个入口节点没有引入该 ...
- 蓝灯github地址
https://github.com/getlantern/lantern/ 闪电联盟蓝灯: http://bbs.sdbeta.com/read-htm-tid-556664.html
- Win7配置Nginx+PHP7
Nginx Nginx有官方native build的32bit版本, 也有cygwin build的64bit版本, 出于稳定性的考虑, 还是选了官方的32bit. 解压, 本例中使用的路径是 C: ...
- 升级nodejs版本
node有一个模块叫n,是专门用来管理node.js的版本的. 首先安装n模块: npm install -g n 第二步: 升级node.js到最新稳定版 n stable n后面也可以跟随版本号比 ...
- 启动PPT的时候一直配置vs2013的问题解决
前几天装了VS2013,结果发现每次启动powerpoint都要配置vs2013,虽然时间花的不多,可我看的就是碍眼,我都想把VS2013卸载来解决了.后来抱着试下的态度竟然在google上找到了解决 ...
- 写Java也得了解CPU--CPU缓存
CPU,一般认为写C/C++的才需要了解,写高级语言的(Java/C#/pathon...)并不需要了解那么底层的东西.我一开始也是这么想的,但直到碰到LMAX的Disruptor,以及马丁的博文,才 ...
- Caffe学习系列(3):视觉层(Vision Layers)及参数
所有的层都具有的参数,如name, type, bottom, top和transform_param请参看我的前一篇文章:Caffe学习系列(2):数据层及参数 本文只讲解视觉层(Vision La ...
- python数字图像处理(19):骨架提取与分水岭算法
骨架提取与分水岭算法也属于形态学处理范畴,都放在morphology子模块内. 1.骨架提取 骨架提取,也叫二值图像细化.这种算法能将一个连通区域细化成一个像素的宽度,用于特征提取和目标拓扑表示. m ...
- Java 基础【08】.class getClass () forName() 详解
类名.class是Class对象的句柄,每个被加载的类,在jvm中都会有一个Class对象与之相对应. 如果要创建新的对象,直接使用Class对象的局部class.forName就可以了,不需要用ne ...