1、什么是函数递归?

函数递归调用(是一种特殊的嵌套调用):在调用的函数过程中,又直接或者间接的调用了该函数本身

递归必须要有两个明确的阶段:

递推:一层一层递归调用下去,强调每进入下一层递归问题的规模都必须有所减少;

回溯:递归必须要有一个明确的结束条件,在满足该条件时结束递推,开始一层层回溯

递归的精髓在于通过不断的重复逼近一个最终的结果

2、怎么用?

# import sys
# print(sys.getrecursionlimit()) #改递归深度
# sys.setrecursionlimit(3000)
# def foo(n):
# print('from foo',n)
# foo(n+1)
# foo(0)
def foo(n):
if n ==1:
return 10
return foo(n-1)+2
print(foo(5))
a =[1,[2,[3,[4,[5,[6,[7,[8,[9,]]]]]]]]]
def tell(a):
for x in a:
if type(x) is list:
tell(x)
else :
print(x)
print(tell(a)) 3、二分法
#二分法
nums=[1,3,7,11,22,34,55,78,111,115,137,149,246,371]
def search(search_num,nums): #传两个参数,一个列表,一个是被检测元素
print(nums)
if len(nums) == 0: #如果是空列表,就没有
print('not exists')
return
mid_index=len(nums) // 2 #取中间的索引值,进而取得所对应的值
if search_num > nums[mid_index]: #判断被检测的元素如果大于列表的中间值
# in the right
nums=nums[mid_index+1:] #截断列表,保留大于中间值的那一段 (从中间值加一的那个值开始,到最后)
search(search_num,nums)
elif search_num < nums[mid_index]: #判断被检测的元素如果小于列表的中间值
# in the left
nums=nums[:mid_index] #截断列表,保留小于中间值的那一段列表
search(search_num,nums)
else:
print('find it') search(34,nums)
4、匿名函数
没有绑定名字用一次就回收了
#有名函数
def fun(x,y):
return x+y
fun(1,2)
#匿名函数格式
res = (lambda x,y: x+y)(1,2)
print(res)
5、内置函数
#max函数应用
salaries={
'egon':3000,
'alex':100000000,
'wupeiqi':10000,
'yuanhao':2000
}
#取工资最高的人名
#max 工资原理
#首先将salaries由可迭代对象变成迭代器对象,通过next方法将迭代器对象取出的值依次传给key指定的函数
#然后将该函数的返回值当作判断依据
def func(k):
return salaries [k]
print(max(salaries,key = func)) #有参数名方法
print(max( salaries, key=lambda k:salaries[k])) #无参数名方法
# 函数sorted
# l=[10,1,3,-9,22]
# print(sorted(l)) #从小到大排序
# l1=sorted(l,reverse=True ) #从大到小排序
# print(l1)
salaries={
'egon':3000,
'alex':100000000,
'wupeiqi':10000,
'yuanhao':2000
}
def func(x):
return (salaries[x])
print(sorted(salaries,key=func ,reverse=True ) ) # print(sorted(salaries ,key=lambda k:salaries[k]) ) #工资从小到大
# print(sorted(salaries ,key=lambda x:salaries[x] ,reverse=True)) #工资从小到大
# map 函数
#将可迭代对象a,变成迭代器对象,通过next方法依次取值,将值做为参数传给指定的函数,函数的返回值就是结果之一
# a =['ffr','ggg','uuu','dfgb']
# a1 =map(lambda x:x+'cc', a)
# print(list(a1)) # filter() 函数 用于过滤序列,过滤掉不符合条件的元素,返回由符合条件元素组成的新列表。
#将可迭代对象变成迭代器对象,用next 方法依次取值,将值作为参数传给指定的函数,
# filter会判断函数的返回值真假,如果为真留下相应的值 names=['alexSB','egon','wxxSB','OLDBOYSB']
# print([x  for x in names  if x.endswith('SB')]) #列表生成式
names1=filter( lambda x: x.endswith('SB'), names)
print(list(names1))


python 函数递归与匿名函数的更多相关文章

  1. Python第七天 函数 函数参数 函数里的变量 函数返回值 多类型传值 函数递归调用 匿名函数 内置函数

    Python第七天   函数  函数参数   函数里的变量   函数返回值  多类型传值     函数递归调用   匿名函数   内置函数 目录 Pycharm使用技巧(转载) Python第一天   ...

  2. python全栈开发-Day12 三元表达式、函数递归、匿名函数、内置函数

    一. 三元表达式 一 .三元表达式 仅应用于: 1.条件成立返回,一个值 2.条件不成立返回 ,一个值 def max2(x,y): #普通函数定义 if x > y: return x els ...

  3. python之旅:三元表达式、列表推导式、生成器表达式、函数递归、匿名函数、内置函数

    三元表达式 #以下是比较大小,并返回值 def max2(x,y): if x > y: return x else: return y res=max2(10,11) print(res) # ...

  4. Python day5 --------递归、匿名函数、高阶函数、内置函数

    一.递归 在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数. 递归要求: 1. 必须有一个明确的结束条件 2. 每次进入更深一层递归时,问题规模相比上次递归都应有所减 ...

  5. Python day10 global关键字、函数递归、匿名函数、map函数的用法详解

    1.global关键字 引用全局变量,在局部全局变量改变,也会改变,global相当于指针,将地址指向全局变量的name name='littlepage' def littepage(): glob ...

  6. python之三元表达式、列表推导、生成器表达式、递归、匿名函数、内置函数

    目录 一 三元表达式 二 列表推到 三 生成器表达式 四 递归 五 匿名函数 六 内置函数 一.三元表达式 def max(x,y): return x if x>y else y print( ...

  7. python协程函数、递归、匿名函数与内置函数使用、模块与包

    目录: 协程函数(yield生成器用法二) 面向过程编程 递归 匿名函数与内置函数的使用 模块 包 常用标准模块之re(正则表达式) 一.协程函数(yield生成器用法二) 1.生成器的语句形式 a. ...

  8. python3 速查参考- python基础 6 -> 函数编程之参数、变量、作用域、递归、匿名函数 lambda

    函数基础 1. 速查笔记 #-- 函数相关的语句和表达式 myfunc('spam') # 函数调用 def myfunc(): # 函数定义 return None # 函数返回值 global a ...

  9. python 三元表达式、列表推导式、生成器表达式、递归、匿名函数、内置函数

    http://www.cnblogs.com/linhaifeng/articles/7580830.html 三元表达式.列表推导式.生成器表达式.递归.匿名函数.内置函数

随机推荐

  1. 20165206 2017-2018-2 《Java程序设计》第6周学习总结

    20165206 2017-2018-2 <Java程序设计>第6周学习总结 教材学习内容总结 String类:可以被直接使用,不可以有子类. String对象:可以使用String类声明 ...

  2. 构造函数与 new 命令

    虽然不同于传统的面向对象编程语言,但是JavaScript具有很强的面向对象编程能力.本章介绍JavaScript如何进行“面向对象编程”. 对象的概念 “面向对象编程”(Object Oriente ...

  3. C++ ifstream ofstream

    原文出自[比特网],转载请保留原文链接:http://soft.chinabyte.com/database/460/11433960.sh [导读] ofstream是从内存到硬盘,ifstream ...

  4. [转]xshell使用技巧

    https://yq.aliyun.com/articles/44721 xshell是我用过的最好用的ssh客户端工具,没有之一.这个软件完全免费,简单易用,可以满足通过ssh管理linux vps ...

  5. python基础——函数

    1.内置函数的调用: 可以在官方网站查找内置函数及说明,也可以通过help(abs)函数查看相应的信息. https://docs.python.org/3/library/functions.htm ...

  6. Python学习(三) —— 基本数据类型

    基本数据类型 一.整数类型(int) 32位机器,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647 64位机器,整数的位数是64位,取值范围位 ...

  7. Codeforces 1045C Hyperspace Highways (看题解) 圆方树

    学了一下圆方树, 好神奇的东西呀. #include<bits/stdc++.h> #define LL long long #define fi first #define se sec ...

  8. 搜狐JS查ip

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. js拷贝

    现在有一个对象 var obj = { name: '隔壁老王', age: 60, sex: 'male' } 我们现在想把obj里的每一个属性拷贝到一个空对象var obj1 = {}中,那么需要 ...

  10. 数仓1.1 分层| ODS& DWD层

    数仓分层 ODS:Operation Data Store原始数据 DWD(数据清洗/DWI) data warehouse detail数据明细详情,去除空值,脏数据,超过极限范围的明细解析具体表 ...