1 2 3 4

5 匿名函数 列表生成式 字典生成式 递归

匿名函数(lambda)

语法

语法格式为 lambda 参数1,参数2,参数(参数可以省略):逻辑表达式(即结果,不可省略),参数的范围(可省略) 

 

常用格式

lambda 参数:结果

lambda x, y: x*y;函数输入是x和y,输出是它们的积x*y
lambda:None;函数没有输入参数,输出是None
lambda *args: sum(args); 输入是任意个数的参数,输出是它们的和(隐性要求是输入参数必须能够进行加法运算)
lambda **kwargs: 1;输入是任意键值对参数,输出是1

一般是组合使用   

# map 映射
l = [1, 2, 3, 4, 5, 6]
print(list(map(lambda x: x + 5, l)))  # 基于for循环  此处l就是参数x 的范围  
# [6, 7, 8, 9, 10, 11]

  

列表生成式(三元表达式)

语法格式

# 列表推导式

# 1:  for 循环的列表推导式  [结果 for循环语句]
res = [i*2 for i in [2,4]]
print(res)

# 2:  if 语句列表推导式
# [if结果  if 语句  else结果  else语句  参数范围]
# 示例一: 将0-9的10个数,奇数用0表示,偶数用1表示
res = [1 if x %2 ==1 else 0 for x in range(10)]
print(res)

  

1. 结合函数结合使

def max(x,y):
  return x if x>y else y  # 比较值大小  

2. 结合匿名函数使用

map(lambda x,y:x-y if x> y else y-x, [2,1,3],[4,3,1])  # 两个列表相减并保证不为负

# [2, 2, 2]

3. 结合列表推导使用 

# 示例一: 将0-9的10个数,奇数用0表示,偶数用1表示
[0 if i % 2 == 0 else 1 for i in range(10)] # [0, 1, 0, 1, 0, 1, 0, 1, 0, 1]

  

字典生成式(字典推导式)

字典推导式和三元表达式用法基本一致

语法

'''
语法一:
key:字典中的key
value:字典中的value
dict.items():序列
condition:条件表达式
key_exp:在for循环中,如果条件表达式condition成立(即条件表达式成立),返回对应的key, value并作key_exp, value_exp处理
value_exp:在for循环中,如果条件表达式condition成立(即条件表达式成立),返回对应的key, value并作key_exp, value_exp处理

{key_exp: value_exp for key, value in dict.items() if condition}


语法二:
key:字典中的key
value:字典中的value
dict.items():序列
condition:条件表达式
key_exp:在for循环中,如果条件表达式condition成立(即条件表达式成立),返回对应的key, value并作key_exp, value_exp处理
value_exp1:在for循环中,如果条件表达式condition成立(即条件表达式成立),返回对应的key, value并作key_exp, value_exp1处理
value_exp2:在for循环中,如果条件表达式condition不成立(即条件表达式不成立),返回对应的key, value并作key_exp, value_exp2处理

{key_exp: value_exp1 if condition else value_exp2 for key, value in dict.items()}
''' 
案例
user_dict = dict()
for i in range(5):
    user_dict[i] = i ** 2
print(user_dict)

# {0: 0, 1: 1, 2: 4, 3: 9, 4: 16}

user_dict = {x: x ** 2 for x in range(5)}
print(user_dict)
# {0: 0, 1: 1, 2: 4, 3: 9, 4: 16}

 

# 获取其中的奇数k,v

original_dict = {0: 0, 1: 1, 2: 4, 3: 9, 4: 16, 5: 25, 6: 36, 7: 49, 8: 64, 9: 81}
user_dict = {k: v for k, v in original_dict.items() if v % 2 ==1}
print(user_dict) # {1: 1, 3: 9, 5: 25, 7: 49, 9: 81}

 

递归 

递归的官方解释 比较绕口   我一般就理解为函数内部调用自己就是递归了 

递归特点

1、必须有一个明确的结束条件
2、每次进入更深一层递归时,问题规模(计算量)相比上次递归都应有所减少
3、递归效率不高,递归层次过多会导致栈溢出(在计算机中,函数调用是通过栈(stack)这种数据结构实现的,每当进入一个函数调用,栈就会加一层栈帧,每当函数返回,栈就会减一层栈帧。由于栈的大小不是无限的,所以,递归调用的次数过多,会导致栈溢出)

关于递归还有两个名词,可以概括递归实现的过程

递推:像上边递归实现所拆解,递归每一次都是基于上一次进行下一次的执行,这叫递推

回溯:则是在遇到终止条件,则从最后往回返一级一级的把值返回来,这叫回溯

最大递归深度

python当中一般认为是 998

 

案例

1、递归求阶乘

# 1!+2!+3!+4!+5!+...+n!
def factorial(n):
    ''' n表示要求的数的阶乘 '''
    if n==1:
        return n # 阶乘为1的时候,结果为1,返回结果并退出
    n = n*factorial(n-1) # n! = n*(n-1)!
    return n  # 返回结果并退出
res = factorial(5) #调用函数,并将返回的结果赋给res
print(res) # 打印结果

2、递归推斐波那契数列

# 1,1,2,3,5,8,13,21,34,55,试判断数列第十五个数是哪个?
def fabonacci(n):
    ''' n为斐波那契数列 '''
    if n <= 2:
        ''' 数列前两个数都是1 '''
        v = 1
        return v # 返回结果,并结束函数
    v = fabonacci(n-1)+fabonacci(n-2) # 由数据的规律可知,第三个数的结果都是前两个数之和,所以进行递归叠加
    return v  # 返回结果,并结束函数
print(fabonacci(15)) # 610    调用函数并打印结果

  

 

 

3、二分法找有序列表指定值

data = [1,3,6,13,56,123,345,1024,3223,6688]
def dichotomy(min,max,d,n):
    '''
    min表示有序列表头部索引
    max表示有序列表尾部索引
    d表示有序列表
    n表示需要寻找的元素
    '''
    mid = (min+max)//2
    if mid==0:
        return 'None'
    elif d[mid]<n:
        print('向右侧找!')
        return dichotomy(mid,max,d,n)
    elif d[mid]>n:
        print('向左侧找!')
        return dichotomy(min,mid,d,n)
    else:
        print('找到了%s'%d[mid])
        return 
res = dichotomy(0,len(data),data,222)
print(res)

  

 

posted @ 2019-03-16 11:22  犹豫就会拜佛  阅读(189)  评论(0编辑  收藏  举报