递归:

递归的概念很简单,如果函数包含了对其自身的调用,该函数就是递归。拗口一点的定义是,如果一个新的调用能在相同过程中较早的调用结束之前开始,那么该过程就是递归。

"""阶乘"""
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 --递归,装饰器的更多相关文章

  1. python递归,装饰器,函数, 高阶函数

    在函数内部,可以调用其它函数,如果一个函数在内部调用自身本身,这个函数就是递归函数 递归特性:1.必须有一个明确的结束条件 2.每次进入更深一层递归时,问题规模比上次递归都有所减少(10-8-5等) ...

  2. python --> 递归 以及装饰器

    一.递归知识 函数迭套执行,逐层执行之后,满足某个条件之后就会停止执行,将return值返回上层的函数,上层函数再逐层返回,最终返回给最初始函数. 递归在斐波那契数列的应用[斐波那契数列特点:前两个数 ...

  3. python学习笔记之装饰器、递归、算法(第四天)

    参考老师的博客: 金角:http://www.cnblogs.com/alex3714/articles/5161349.html 银角:http://www.cnblogs.com/wupeiqi/ ...

  4. 学习PYTHON之路, DAY 5 - PYTHON 基础 5 (装饰器,字符格式化,递归,迭代器,生成器)

    ---恢复内容开始--- 一 装饰器 1 单层装饰器 def outer(func): def inner(): print('long') func() print('after') return ...

  5. python-学习笔记之-Day5 双层装饰器 字符串格式化 python模块 递归 生成器 迭代器 序列化

    1.双层装饰器 #!/usr/bin/env python # -*- coding: utf-8 -*- # author:zml LOGIN_INFO = False IS_ADMIN = Fal ...

  6. python_way ,day5 模块,模块3 ,双层装饰器,字符串格式化,生成器,递归,模块倒入,第三方模块倒入,序列化反序列化,日志处理

    python_way.day5 1.模块3 time,datetime, json,pickle 2.双层装饰器 3.字符串格式化 4.生成器 5.递归 6.模块倒入 7.第三方模块倒入 8.序列化反 ...

  7. Python(迭代器 生成器 装饰器 递归 斐波那契数列)

    1.迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大优 ...

  8. Day5 双层装饰器、字符串格式化、生成器、迭代器、递归

    双层装饰器实现用户登录和权限认证 #!/usr/bin/env python# -*- coding: utf-8 -*-# Author: WangHuafeng USER_INFO = {} de ...

  9. Python学习笔记 (4) :迭代器、生成器、装饰器、递归、正则表达式等

    迭代器 迭代器是访问集合元素的一种方式.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退,不过这也没什么,因为人们很少在迭代途中往后退.另外,迭代器的一大优点是 ...

随机推荐

  1. charCode与keyCode的区别

    在标准浏览器下获取键盘按键我们可以使用e.which,但是非标准下没有这个属性,所以大部分情况下用keyCode,但是这是存在兼容性问题的.我们来看下他两的区别: onkeydown: e.keyCo ...

  2. mysql下mysqladmin日常管理命令总结

    mysqladmin 工具的使用格式:mysqladmin [option] command [command option] command ......参数选项:-c number 自动运行次数统 ...

  3. Linux下误删除后的恢复操作(ext3/ext4)

    Linux是作为一个多用户.多任务的操作系统,文件一旦被删除是难以恢复的.尽管删除命令只是在文件节点中作删除标记,并不真正清除文件内容,但是其他用户和一些有写盘动作的进程会很快覆盖这些数据.在日常工程 ...

  4. PAT 1018. 锤子剪刀布 (20)

    现给出两人的交锋记录,请统计双方的胜.平.负次数,并且给出双方分别出什么手势的胜算最大. 输入格式: 输入第1行给出正整数N(<=105),即双方交锋的次数.随后N行,每行给出一次交锋的信息,即 ...

  5. Codevs 1229 数字游戏

    1229 数字游戏  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 白银 Silver     题目描述 Description Lele 最近上课的时候都很无聊,所以他发明了 ...

  6. POJ 3714 Raid

    Description After successive failures in the battles against the Union, the Empire retreated to its ...

  7. Eclipse使用Maven构建web项目

    1.创建Maven项目: 点击“File”菜单,或者通过工具栏的“New”创建Project,如下图所示: 选择Maven->Maven Project,弹出向导对话框,如下图所示: 选中Cre ...

  8. node基础03:使用函数

    1.使用函数 //server.js var http = require("http"); var output = require("./output"); ...

  9. .html 、.htm 、 .shtml 以及 .shtm 四种扩展名的文件区别

    新增了一个分类,叫做 Personals,中文我把它解释成 "个人恶趣味",这里将记载一些对工作无关紧要,但是个人又一时有兴趣了解的东西. 今天要讲的是如题的 4 种扩展文件的区别 ...

  10. 知乎日报win10版 - 天天读报【开源】

    业余时间写的一个知乎日报win10版客户端,支持收藏,评论,点赞等. 商店地址:https://www.microsoft.com/zh-cn/store/apps/%E5%A4%A9%E5%A4%A ...