一. 匿名函数

  为了解决一些简单的需求而设计的一句话函数.  lambda表示的是匿名函数. 不需要用def来声明, 一句话就可以声明出一个函数

   语法:    函数名 = lambda 参数: 返回值

a = lambda x, y: x + y  # lambda 匿名函数 一行搞定一个函数. 但是, 不能完成复杂的函数操作
print(a(2, 5)) #
print(a.__name__) #
b = lambda x, y: x * y
print(b(4, 5)) #

  与sorted()在一起用

lst = [{'id': 1, 'name': 'jack', 'age': 18},
{'id': 2, 'name': 'tom', 'age': 55},
{'id': 3, 'name': 'jerry', 'age': 33},
{'id': 4, 'name': 'steve', 'age': 22},
{'id': 5, 'name': 'ben', 'age': 18},
]
l1 = sorted(lst, key=lambda dic:dic['age']) #根据列表里的字典的年龄大小来排序
print(l1)
# [{'id': 1, 'name': 'jack', 'age': 18}, {'id': 5, 'name': 'ben', 'age': 18},
# {'id': 4, 'name': 'steve', 'age': 22}, {'id': 3, 'name': 'jerry', 'age': 33},
# {'id': 2, 'name': 'tom', 'age': 55}]

  与filter()一起用 

lst = [{'id': 1, 'name': 'jack', 'age': 18},
{'id': 2, 'name': 'tom', 'age': 55},
{'id': 3, 'name': 'jerry', 'age': 33},
{'id': 4, 'name': 'steve', 'age': 44},
{'id': 5, 'name': 'ben', 'age': 22},
]
li = filter(lambda dic: dic['age'] > 40, lst) #过滤掉列表里年龄没有超过40的字典
print(list(li))
# [{'id': 2, 'name': 'tom', 'age': 55}, {'id': 4, 'name': 'steve', 'age': 44}]

  与map()一起用

lst1 = [1, 2, 3, 4, 5]
lst2 = [6, 7, 8, 9, 10]
print(list(map(lambda x, y: x + y, lst1, lst2))) #把两个列表索引相同的元素相加,组成一个新列表
#[7, 9, 11, 13, 15]

二. 递归函数

   在函数中调用函数本身. 就是递归.

def f():
print('hello ,world')
f() #调用自身
f() #最多调用996层,然后报错
import sys
sys.setrecursionlimit(10000) # 可以调整递归深度. 但是不一定能跑到

  递归的应用: 可以使用递归来遍历各种树形结构, 比如文件夹系统. 可以使用递归来遍历该文件夹中的所有文件.

# 遍历树形结构
import os
filePath = "d:\pycharm"
def read(filePath, n): #n的值可以用来对文件缩进
it = os.listdir(filePath) # 打开文件夹
for el in it:
# 拿到路径
fp = os.path.join(filePath, el) # 获取到绝对路径
if os.path.isdir(fp): # 判断是否是文件夹
print("\t"*n,el) #通过n的大小来对文件夹进行缩进
read(fp, n+1) # 又是文件夹. 继续读取内部的内容 递归入口
else:
print("\t"*n,el) # 递归出口 read(filePath, 0) #初始值为0,第一层文件夹不用缩进

三. 二分查找

    二分查找. 每次能够排除掉一半的数据, 查找的效率非常高, 但是局限性比较大, 必须是有序列才可以使用而分查找

  要求: 查找的序列必须是有序列.

# 判断n是否在lst中出现. 如果出现请返回n所在的位置
# 二分查找: 非递归算法
lst = [11,22,33,44,55,66,77,88,99,123,234,345,456,567,678,789,1111]
n = 567
left = 0
right = len(lst) - 1
count = 1
while left <= right: #当作表索引小于等于右边索引,可以继续比较
middle = (left + right) // 2 #中间索引
if n > lst[middle]: #若n大于中间值,则n的取值在右边部分,middle的索引需要向右移动一位
left = middle + 1
elif n < lst[middle]: #若n小于中间值,则n的取值在左边部分,middle的索引需要向左移动一位
right = middle - 1
else:
print(count) #比较的次数
print("存在")
print(middle)
break
count = count + 1
else:
print("不存在")
# 普通递归版本二分法
lst = [11,22,33,44,55,66,77,88,99,123,234,345,456,567,678,789,1111]
def binary_search(left, right, n): #左右两边索引,和判断的数字这三个参数
middle = (left + right)//2
if left > right: #比较结束后没有n的值,再进行比较时就会出现左索引大于右边索引,
return -1
if n > lst[middle]:
left = middle + 1
elif n < lst[middle]:
right = middle - 1
else:
return middle
return binary_search(left, right, n) #加return需要获得再次调用的返回值
print(binary_search(0, len(lst)-1, 65) )

lamda匿名函数(与sorted(),filter(),map() 一起用), 递归函数, 二分查找的更多相关文章

  1. 小学生都能学会的python(<lamda匿名函数,sorted(),filter(),map(),递归函数>)

    小学生都能学会的python(<<lamda匿名函数,sorted(),filter(),map(),递归函数,二分法>> 1. lambda 匿名函数 lambda 参数: ...

  2. python 内置函数,匿名函数,sorted,filter,map,递归,二分法,冒泡算法 eval

    ############################总结#################################1. lambda 匿名函数 语法——lambda 参数:返回值 __na ...

  3. 匿名函数、sorted()、filter()、map()、递归

    一.匿名函数 1.lambda 匿名函数 方法 lambda 参数:返回值 (函数名统一叫lambda) def func(n): return n**2 print(func(3)) #这是一个普通 ...

  4. 内置函数二(lambda函数,sorted(),filter(),map(),递归函数,二分法查找)

    一,匿名函数 lambda表⽰示的是匿名函数. 不需要⽤用def来声明, ⼀一句句话就可以声明出⼀一个函数 语法:    函数名 = lambda 参数: 返回值 注意: 1. 函数的参数可以有多个. ...

  5. python之内置函数(lambda,sorted,filter,map),递归,二分法

    一.lambda匿名函数 为了解决一些简单需求而设计的一句话函数,lambda表示的是匿名函数,不需要用def来声明,一句话就可以声明出一个函数. 语法: 函数名 = lambda 参数 : 返回值 ...

  6. 内置函数 lambda sorted filter map 递归

    一 lambda 匿名函数 为了解决一些简单的需求而设计的一句话函数 # 计算 n 的 n次方 def func(n): return n**n print(func(10)) f = lambda ...

  7. Python【day 14-4】sorted filter map+递归文件夹+二分法查找

    def func(x): #普通函数 return x*x ret1 = func(10) #匿名函数 f = lambda x:x*x # 匿名函数写法: 匿名函数名=lambda 参数:返回值 ' ...

  8. 内置函数之sorted,filter,map

    # 4,用map来处理字符串列表,把列表中所有人都变成sb,比方alex_sb # name=['oldboy','alex','wusir'] # print(list(map(lambda i:i ...

  9. Python【day 14-5】sorted filter map函数应用和练习

    '''''' ''' 内置函数或者和匿名函数结合输出 4,用map来处理字符串列表,把列表中所有人都变成sb,比方alex_sb name=[‘oldboy’,'alex','wusir'] 5,用m ...

随机推荐

  1. 重新生成ssh

    解决码云出现git@gitee.com: Permission denied (publickey). 很久之前好像改了ssh的一些配置,导致现在对git进行一些操作时,就会出现 当时就去百度,结果很 ...

  2. Java中的Graphics2D类基本使用教程

    Java语言在Graphics类提供绘制各种基本的几何图形的基础上,扩展Graphics类提供一个Graphics2D类,它拥用更强大的二维图形处理能力,提供.坐标转换.颜色管理以及文字布局等更精确的 ...

  3. [原] Android上使用native IO

    首先, 官方google play对APK大小有限制: 50M.( https://support.google.com/googleplay/android-developer/answer/113 ...

  4. Centos7快速安装haproxy

    HAProxy是一个使用C语言编写的自由及开放源代码软件[1],其提供高可用性.负载均衡,以及基于TCP和HTTP的应用程序代理. HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要 ...

  5. gdb入门

    下面是我自己写的一个测试用例 a.c #include<stdio.h> int add(int a,int b){ return a+b; } int main(){ int n=add ...

  6. Match 3 小项目学习

    using UnityEngine; using System.Collections; using Holoville.HOTween; /// <summary> /// 游戏逻辑 / ...

  7. 996.icu 事件后

    996.icu 事件后 雇主 更加关注效率 减少成本 分工再细化 精简人员 雇员 法律意识加强 个人权利争取 效率低者下岗 技能提高 效率提高 影响 商业社会更有效率 人力市场竞争更加激烈 国内竞争力 ...

  8. idea 中maven编译速度过慢的问题的解决

    解决方案一 在创建Maven项目时加上 archetypeCatalog=internal 参数,如下: 解决方案二 在maven的VM Options加上-DarchetypeCatalog=int ...

  9. LDAP服务器的概念和原理简单介绍

    LDAP服务器的概念和原理简单介绍 1. 目录服务 目录是一个为查询.浏览和搜索而优化的专业分布式数据库,它呈树状结构组织数据,就好象Linux/Unix系统中的文件目录一样.目录数据库和关系数据库不 ...

  10. redis设计与实现-数据结构

    1,redis存储有5种数据对象,有7种数据结构底层实现 2,sds简单字符串 不直接使用字符数组或是string 封装了长度变量,加快获得字符串长度 杜绝缓冲区溢出(拼接字符串的时候不会因为内存里连 ...