python里使用reduce()函数

2025-02-11 17:10分类:五子棋游戏 阅读:

 

reduce()函数在库functools里,如果要使用它,要从这个库里导入。reduce函数与map函数有不一样地方,map操作是并行操作,reduce函数是把多个参数合并的操作,也就是从多个条件简化的结果,在计算机的算法里,大多数情况下,就是为了简单化。比如识别图像是否是一只猫,那么就是从众多的像素里提炼出来一个判断:是或否。可能是几百万个像素,就只出来一个结果。在GOOGLE大规模集群里,就是利用这个思想,把前面并行处理的操作叫做map,并行处理之后的结果,就需要简化,归类,把这个简化和归类的过程就叫做reduce。由于reduce只能在一台主机上操作,并不能分布式地处理,但是reduce处理的是map结果,那么意味着这些结果已经非常简单,数据量大大减小,处理起来就非常快。因此可以把mapreduce过程叫做分析归纳的过程。

看一下面reduce()的例子:

#python 3. 6
#蔡军生 
#http://blog.csdn.net/caimouse/article/details/51749579
#
from functools import reduce
result = reduce(lambda x, y: x+y, [1, 2, 3, 4, 5])
print(result)

输出结果:

15

在这个例子里,其实计算过程是这样的:

((((1+2)+3)+4)+5)

再看一个阶乘的例子:

#python 3. 6
#蔡军生 
#http://blog.csdn.net/caimouse/article/details/51749579
#
from functools import reduce
n = 3
print(reduce(lambda x, y: x * y, range(1, n + 1)))  # 6

输出结果:

reduce函数,reduce函数会对参数序列中元素进行累积。

reduce函数的定义:

五子棋游戏开发_五子棋开局软件_五子棋游戏源码

reduce(function, sequence[, initial]) -> value

function参数是一个有两个参数的函数,reduce依次从sequence中取一个元素,和上一次调用function的结果做参数再次调用function。

第一次调用function时,如果提供initial参数,会以sequence中的第一个元素和initial作为参数调用function,否则会以序列sequence中的前两个元素做参数调用function。

reduce(lambda x, y: x + y, [2, 3, 4, 5, 6], 1)

结果为21( (((((1+2)+3)+4)+5)+6) )

reduce(lambda x, y: x + y, [2, 3, 4, 5, 6])

结果为20

深入浅出Numpy

Python游戏开发入门

你也能动手修改C编译器

纸牌游戏开发 五子棋游戏开发

RPG游戏从入门到精通

WiX安装工具的使用

俄罗斯方块游戏开发

boost库入门基础

Arduino入门基础

Unity5.x游戏基础入门

TensorFlow API攻略

TensorFlow入门基本教程

C++标准模板库从入门到精通

跟老菜鸟学C++

跟老菜鸟学python

在VC2015里学会使用tinyxml库

在Windows下SVN的版本管理与实战

Visual Studio 2015开发C++程序的基本使用

在VC2015里使用protobuf协议

在VC2015里学会使用MySQL数据库

上一篇:python里使用socket实现时间同步

下一篇:没有了

相关推荐


最新更新

推荐阅读

猜你喜欢

关注我们

    五子棋|五子棋必胜阵法|五子棋规则|五子棋游戏|五子棋的下法|五子棋技巧|五子棋棋谱|五子棋教程
返回顶部