lambda,sorted(),filter(),map(),递归,二分法
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(),递归,二分法的更多相关文章
- Day14--Python--函数二,lambda,sorted,filter,map,递归,二分法
今日主要内容:1. lambda 匿名函数 lambda 参数: 返回值-------------------------------------def square(x): return x**2 ...
- python之内置函数(lambda,sorted,filter,map),递归,二分法
一.lambda匿名函数 为了解决一些简单需求而设计的一句话函数,lambda表示的是匿名函数,不需要用def来声明,一句话就可以声明出一个函数. 语法: 函数名 = lambda 参数 : 返回值 ...
- 内置函数 lambda sorted filter map 递归
一 lambda 匿名函数 为了解决一些简单的需求而设计的一句话函数 # 计算 n 的 n次方 def func(n): return n**n print(func(10)) f = lambda ...
- Python【day 14-4】sorted filter map+递归文件夹+二分法查找
def func(x): #普通函数 return x*x ret1 = func(10) #匿名函数 f = lambda x:x*x # 匿名函数写法: 匿名函数名=lambda 参数:返回值 ' ...
- Python_Mix*匿名函数,sorted,filter,map,递归函数,二分法查找
lambda匿名函数(函数名统一都叫lambda) 为了解决简单的需求而设计的一句话函数 语法: lambda 参数 返回值 n = lambda a,b: max(a,b) ret = n(9,4) ...
- 小学生都能学会的python(<lamda匿名函数,sorted(),filter(),map(),递归函数>)
小学生都能学会的python(<<lamda匿名函数,sorted(),filter(),map(),递归函数,二分法>> 1. lambda 匿名函数 lambda 参数: ...
- lambda匿名函数,sorted(),filter(),map(),递归函数
1.lambda匿名函数 为了解决一些简单的需求而设计的一句话函数 #计算n的n次方 def func(n): return n**n print(func(10)) f = lambda n: n* ...
- 匿名函数 sorted() filter() map() 递归函数
一. lambda() 匿名函数 说白了,从字面理解匿名函数就是看不见的函数,那么他的看不见表现在哪里呢? 其实就是在查询的时候他们的类型都是lambda的类型所以叫匿名,只要是用匿名函数写的大家 ...
- sorted() ,filter() ,map()的用法
sorted() 排序函数. 语法: sorted(Iterable, key=None, reverse=False) Iterable: 可迭代对象 key: 排序规则(排序函数), 在sorte ...
随机推荐
- Unity 3D游戏-见缝插针源码
Unity见缝插针功能实现 本文提供全流程,中文翻译.Chinar坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) 1 Sphere Rotatio ...
- LOJ2542. 「PKUWC2018」随机游走【概率期望DP+Min-Max容斥(最值反演)】
题面 思路 我们可以把到每个点的期望步数算出来取max?但是直接算显然是不行的 那就可以用Min-Max来容斥一下 设\(g_{s}\)是从x到s中任意一个点的最小步数 设\(f_{s}\)是从x到s ...
- 51Nod 1009:1009 数字1的数量 (思维)
1009 数字1的数量 基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题 收藏 关注 给定一个十进制正整数N,写下从1开始,到N的所有正数,计算出其中出现所有1的 ...
- ElasticSearch(五):简单的ElasticSearch搜索功能
这里主要是一些简单的ElasticSearch的搜索功能,复杂的搜索,比如过滤,聚合等以后单独在写 1. 搜索全部 GET book/_search 直接搜索全部,下面是对搜索结果的详细介绍:默认情况 ...
- ZOJ 3551 吸血鬼 概率DP
解题报告链接: http://www.cnblogs.com/183zyz/archive/2012/09/13/2683524.html 做法:设当有i个吸血鬼时变成n个吸血鬼的天数的数学期望为dp ...
- CTF-练习平台-Social之 密码?
一.密码? 看到题目提示是“张三”“生日”,再联系到我们设置密码时一般是名字的拼音首字母加生日,所以猜测是:zs19970315尝试后正确.
- 计算n^k的开头三位和末尾三位(fmod(double x,double y)函数的引入)
C 库函数 double fmod(double x, double y) 返回 x 除以 y 的余数. 所以fmod(x,1)得到的就是小数部分的值(如fmod(3.35,1)==0.35) htt ...
- 杭电OJ1789、南阳OJ236(贪心法)解题报告
杭电OJ1789http://acm.hdu.edu.cn/showproblem.php?pid=1789 南阳OJ236http://59.69.128.203/JudgeOnline/probl ...
- hdu 5312 dp(背包)、二分图或其他姿势
题意:给出一个二分图(不一定连通),问最多能加多少边,使它仍然是二分图 BC周年庆第四题,貌似终判再终判之后数据还是有问题``` 据说貌似可以用bitset搞,而且姿势优美是正解```然而我还是用的d ...
- Dataframe 取列名
1.[column for column in df] 2.df.columns.values 返回 array 3.list(df) 4.df.columns 返回Index,可以通过 tolist ...