Map Filter和Reduce函数

来源:互联网 发布:小海家淘宝 编辑:程序博客网 时间:2024/06/05 05:30

Map Filter和Reduce函数

Map函数

map中文意思是映射,和数学中的集合映射是一样的

a = [1,2,3,4,5] #集合adef f (x):      #映射规则f(x)        return x*xb = map(f, a)   #每一个x属于a 经过映射规则产生b集合,b集合是a集合的一个满射(python3返回的是一个迭代器)print(list(b))'''结果:[1, 4, 9, 16, 25]'''

Filter函数

filter意思是过滤器,过滤掉不需要的留下需要的。

a = [1,2,3,4,5 ]    #集合adef f(x):           #映射规则f(x) ->[true,false] 相当于f(x)和Filter的复合映射,if f(x)== true: return x        return x>3b = filter(f, a)    #留下f(x)=true 的xprint(list(b))'''结果:[4, 5]'''

Reduce函数

Reduce的含义有减少;缩小;归纳为,这我我觉得它的意思倾向于归纳。

from functools import reduce #需要引入reducea = [1,2,3,4,5]def f( a, b ):        print(a,b)        return a+b;b = reduce( f, a )print(b)'''结果:1 23 36 410 515从结果可以看出 如果a为一个数列[a0,a1,a2,...,an]a前n项和为S[n] = S[n-1] + anf就是用来数列求和的作用,S[n] = f(S[n-1],an)'''
2 0
原创粉丝点击