pyhthon --递归,装饰器

时间:2022-09-08 21:41:47

递归:

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

"""阶乘"""
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. 免费图片存储和图话【提供demo下载】

    我们不管是做博客系统还是其他网站,图片是免不了要使用到的.但是,我们都知道图片的访问是很耗资源的,同时也是很占磁盘空间的,且还特别占带宽. 所以,我们一般都会用到特定的图片服务器.不过,像我等屌丝平时 ...

  2. HDU 1241 (DFS搜索+染色)

    题目链接:  http://acm.hdu.edu.cn/showproblem.php?pid=1241 题目大意:求一张地图里的连通块.注意可以斜着连通. 解题思路: 八个方向dfs一遍,一边df ...

  3. db2建立表空间

    --缓冲池 CREATE BUFFERPOOL EMP_BUF_POOL  IMMEDIATE  ALL DBPARTITIONNUMS  SIZE 250  NUMBLOCKPAGES 0  PAG ...

  4. java判断某个字符串包含某个字符串的个数

    /** * 判断str1中包含str2的个数 * @param str1 * @param str2 * @return counter */ public static int countStr(S ...

  5. 一个好用的几乎没有Callback的Android异步库

    android-async-task 这是一个Android平台处理复杂异步任务的库 (https://github.com/gplibs/android-async-task) 1. 安装方法 gr ...

  6. 1638: [Usaco2007 Mar]Cow Traffic 奶牛交通

    1638: [Usaco2007 Mar]Cow Traffic 奶牛交通 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 618  Solved: 217 ...

  7. JAVA程序打包成exe小程序的过程

    编程软件:myeclipse2014 打包exe软件:exe4j 1:在myeclipse2014新建java项目编写程序 2:打包成jar,分两种情况(有无外部依赖包) 无外部依赖包:点击项目--- ...

  8. SQL SERVER镜像切换

    --SQL SERVER镜像切换 ------------------------------2013/11/30 切换条件   高性能 没有见证服务器的高安全性模式 具有见证服务器的高安全性模式 自 ...

  9. jQuery 选择器 (一)

    选择器 实例 选取 * $("*") 所有元素 #id $("#lastname") id="lastname" 的元素 .class $( ...

  10. javascript中通过元素id和name直接取得元素

    我们知道一些第三方的js库对如何快速选取html中的元素做了一些简化,貌似十分高深莫测,其实也不然.而且js本身自带了对于特殊元素的简便选取的方法,下面就为大家简单介绍下. 在html中,一般最直接的 ...