1. lambda 匿名函数    语法:        lambda 参数:返回值        不能完成复杂的操作例
# li=['21','asdd','weqeqw','wqf']# # it=iter(li)# # print(next(it))# # print(next(it))# ## it=li.__iter__()# print(it.__next__())### s="heihei21"# print(hash(s))

# import  os# name=input('请输入要内幕:')# __import__(name)# # print(name)# print(help(str))# print(dir(str))# a=11# print(type(a))# print(bin(20))# print(hex(20))# print(oct(20))# a=10# print(callable(a))

2. sorted() 函数    排序.    1. 可迭代对象    2. key=函数. 排序规则    3. reverse. 是否倒序例
# lst = [5,7,6,12,1,13,9,18,5]# # lst.sort()  # sort是list里面的一个方法# # print(lst)## ll = sorted(lst, reverse=True) # 内置函数. 返回给你一个新列表  新列表是被排序的# print(ll)

# 给列表排序. 根据字符串的长度进行排序lst = ["大阳哥a", "尼古拉斯aa", "赵四aaa", "刘能a", "广坤aaaaaa", "谢大脚a"]## def func(s):#     return s.count('a') #  返回数字## ll = sorted(lst, key=lambda s:s.count('a')) # 内部. 把可迭代对象中的每一个元素传递给func# print(ll)## lst = [#         {'id':1, 'name':'alex', 'age':18},#         {'id':2, 'name':'taibai', 'age':58},#         {'id':3, 'name':'wusir', 'age':38},#         {'id':4, 'name':'ritian', 'age':48},#         {'id':5, 'name':'女神', 'age':18}#        ]## ll = sorted(lst, key=lambda dic:dic['age'], reverse=True)# print(ll)
3. filter() 函数    过滤    1. 函数, 返回True或False    2. 可迭代对象例
# def func(i):    # 判断奇数#     return i % 2 == 1lst = [1,2,3,4,5,6,7,8,9]

ll = filter(lambda i:i%2==1, lst)#  第一个参数. 函数. 将第二个参数中的每一个元素传给函数. 函数如果返回True, 留下该元素.# print("__iter__" in dir(ll))# print("__next__" in dir(ll))# print(list(ll))

# lst = [#         {'id':1, 'name':'alex', 'age':18},#         {'id':2, 'name':'taibai', 'age':58},#         {'id':3, 'name':'wusir', 'age':38},#         {'id':4, 'name':'ritian', 'age':48},#         {'id':5, 'name':'女神', 'age':18}#        ]## print(list(filter(lambda dic: dic['age']>40, lst)))

4. map() 映射函数    1. 函数    2. 可迭代对象例
# lst = [1,2,3,4,5,6,7,8,9,0,23,23,4,52,35,234,234,234,234,234,23,4]# it = map(lambda i: i * i, lst) # 把可迭代对象中的每一个元素传递给前面的函数进行处理. 处理的结果会返回成迭代器# print(list(it))

# lst1 = [ 1, 2, 3, 4, 5]# lst2 = [ 2, 4, 6, 8]# print(list(map(lambda x, y:x+y, lst1, lst2))) # 如果函数中有多个参数. 后面对应的列表要一一对应
5. 递归    自己调用自己.    def func():        func()    func()    难点:不好想.需要找规律. 不好读例
# import sys# sys.setrecursionlimit(10000)    # 可以调整递归深度. 但是不一定能跑到这里# def func(count):#     print("我是谁,我在哪里"+str(count))#     func(count+1)# func(1)

# while 1:#     a = 10#     print("哈哈")

# 遍历树形结构# import  os# filePath = "d:\sylar\python_workspace"## def read(filePath, n):#     it = os.listdir(filePath)   # 打开文件夹#     for el in it:#         #  拿到路径#         fp = os.path.join(filePath, el) # 获取到绝对路径#         if os.path.isdir(fp):   # 判断是否是文件夹#             print("\t"*n,el)#             read(fp, n+1)    # 又是文件夹. 继续读取内部的内容 递归入口#         else:#             print("\t"*n,el)    # 递归出口## read(filePath, 0)

6. 二分法    掐头结尾取中间. 不停的改变左和右. 间接改变中间. 查询效率非常高例
# 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]:#         left = middle + 1#     elif n < lst[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:#         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)# print(binary_search(0, len(lst)-1, 65) )

# def binary_search(lst, n):#     left = 0#     right = len(lst) - 1#     middle = (left + right) // 2#     if right <= 0:#         print("没找到")#         return#     if n > lst[middle]:#         lst = lst[middle+1:]#     elif n < lst[middle]:#         lst = lst[:middle]#     else:#         print("找到了")#         return#     binary_search(lst, n)# binary_search(lst, 65)

lambda,sorted(),filter(),map(),递归,二分法的更多相关文章

  1. Day14--Python--函数二,lambda,sorted,filter,map,递归,二分法

    今日主要内容:1. lambda 匿名函数 lambda 参数: 返回值-------------------------------------def square(x): return x**2 ...

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

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

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

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

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

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

  5. Python_Mix*匿名函数,sorted,filter,map,递归函数,二分法查找

    lambda匿名函数(函数名统一都叫lambda) 为了解决简单的需求而设计的一句话函数 语法: lambda 参数 返回值 n = lambda a,b: max(a,b) ret = n(9,4) ...

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

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

  7. lambda匿名函数,sorted(),filter(),map(),递归函数

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

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

    一. lambda() 匿名函数   说白了,从字面理解匿名函数就是看不见的函数,那么他的看不见表现在哪里呢? 其实就是在查询的时候他们的类型都是lambda的类型所以叫匿名,只要是用匿名函数写的大家 ...

  9. sorted() ,filter() ,map()的用法

    sorted() 排序函数. 语法: sorted(Iterable, key=None, reverse=False) Iterable: 可迭代对象 key: 排序规则(排序函数), 在sorte ...

随机推荐

  1. c++  与  java  中的 继承

    C++ 代码: #include <iostream> #include <string> using namespace std; class Parent { public ...

  2. 一致性哈希算法(Consistent Hashing Algorithm)

    一致性哈希算法(Consistent Hashing Algorithm) 浅谈一致性Hash原理及应用   在讲一致性Hash之前我们先来讨论一个问题. 问题:现在有亿级用户,每日产生千万级订单,如 ...

  3. TensorFlow笔记-06-神经网络优化-损失函数,自定义损失函数,交叉熵

    TensorFlow笔记-06-神经网络优化-损失函数,自定义损失函数,交叉熵 神经元模型:用数学公式比表示为:f(Σi xi*wi + b), f为激活函数 神经网络 是以神经元为基本单位构成的 激 ...

  4. 基于 FastAdmin 开发后台流程 (持续更新)

    使用 git init 初始化 增加一个自己的git 原始仓库,用于存放自己的代码. 增加一个 fastadmin 的仓库,为了方便以后与官方同步. 自己修改的代码 git Push 到自己的仓库 将 ...

  5. 【转】每天一个linux命令(38):cal 命令

    原文网址:http://www.cnblogs.com/peida/archive/2012/12/14/2817473.html cal命令可以用来显示公历(阳历)日历.公历是现在国际通用的历法,又 ...

  6. bzoj 3622 已经没有什么好害怕的了——二项式反演

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3622 令 f[i] 表示钦定 i 对 a[ ]>b[ ] 的关系的方案数:g[i] 表 ...

  7. script 标签的defer,async的作用,及拓展浏览器多线程,DOMContentLoaded

    前端优化有一点就是优化js的执行时机,一般做法是将script放置于body的结束标签,以避免加载执行js 文件导致页面渲染阻塞的问题这种做法确实能防止页面阻塞,但是在页面渲染完成之后才去加载js文件 ...

  8. Hanlp中文自然语言处理入门介绍

    自然语言处理定义: 自然语言处理是一门计算机科学.人工智能以及语言学的交叉学科.虽然语言只是人工智能的一部分(人工智能还包括计算机视觉等),但它是非常独特的一部分.这个星球上有许多生物拥有超过人类的视 ...

  9. HighCharts定时刷新图表

    假设图表容器的id为exChart,如下: <div style="height:450px;" id="chart">   1. 首先在serie ...

  10. asp.net后台正则表达式验证手机号码邮箱

    //如果文本中可以为空的为NO,文本中内容不为空 if (input.nullable == "no" || !isnull(input.value)) { //文本中值的类型 s ...