Python----浅谈map和reduce

map和reduce都是python里面的高阶函数

高阶函数简单来说就是:一个函数可以将函数作为自身的参数,则称之为高阶函数

哦哟哟,是不是比一般性的函数厉害那么一点点,那么map和reduce是不是也会厉害那么一些呢?------是的(反正我觉得map是的,reduce对不起)

来,先介绍一下map函数的定义:

map()函数接收两个参数,一个是函数,一个是Iterablemap将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回

这里有人会问Iterator是什么,百度去吧少年,大概说一下反正List和str是的,必须可以由for循环的变量,当然这只是初步的,但显然int就不是了嘛

给个map函数的示范吧,一看就懂

从这里我们可以看出一个特性,map函数因为有一个参数是Iterable,并且这也是对Iterable进行操作,那么结果必然是惰性的,这是Iterable的性质,那么产生的结果可以用next()依次输出,也可以才改变形态后一下子全输出,这取决于你想干嘛咯

好咯,接下来就是reduce了

reduce也接收两个参数一个是函数,一个是变量(注意,不用是Iterable,所以没惰性),但作用不同:reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)

emmmm……这么大概可以理解吧,给个辅助例子吧

猜你喜欢

转载自blog.csdn.net/qq_42192672/article/details/81268485