zoukankan      html  css  js  c++  java
  • 4、reduce函数工具的使用

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

    因此可以把mapreduce过程叫做分析归纳的过程。

    看一下面reduce()的例子:

    from functools import reduce
      
    result = reduce(lambda x, y: x+y, [1, 2, 3, 4, 5])
    print(result)

    输出结果:

    15

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

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

    再看一个阶乘的例子:

    from functools import reduce
      
    n = 3
    print(reduce(lambda x, y: x * y, range(1, n + 1))) # 6

    输出结果:

    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

    一个初识C++的小白
  • 相关阅读:
    GridSplitterProperties
    软件趋势是什么?
    Chinaren,逐渐变为垃圾了。
    【JS】回调函数示例
    在编程的海洋里 有蟛蜞喜欢在浅滩栖居嬉戏 也有巨鲸在远洋遨游
    【JS】两个计时器的写法
    【Java/Regexp】如何把MyBatis中的占位符#{name} 或是拼接符${name}中的变量名称拿出来
    【JS】利用中国古老的天干地支给文件命名
    【JS】利用闭包自制的沙漏类
    【Java】十进制和十六进制的转换
  • 原文地址:https://www.cnblogs.com/Real-m/p/13614234.html
Copyright © 2011-2022 走看看