python中reduce()函数
来源:互联网 发布:旅游大数据分析 编辑:程序博客网 时间:2024/05/22 06:39
reduce()函数也是Python内置的一个高阶函数。reduce()函数接收的参数和 map()类似,一个函数 f,一个list,但行为和 map()不同,reduce()传入的函数 f 必须接收两个参数,reduce()对list的每个元素反复调用函数f,并返回最终结果值。
例如,编写一个f函数,接收x和y,返回x和y的和:
def f(x, y): return x + y
调用 reduce(f, [1, 3, 5, 7, 9])时,reduce函数将做如下计算:
先计算头两个元素:f(1, 3),结果为4;再把结果和第3个元素计算:f(4, 5),结果为9;再把结果和第4个元素计算:f(9, 7),结果为16;再把结果和第5个元素计算:f(16, 9),结果为25;由于没有更多的元素了,计算结束,返回结果25。
上述计算实际上是对 list 的所有元素求和。虽然Python内置了求和函数sum(),但是,利用reduce()求和也很简单。
reduce()还可以接收第3个可选参数,作为计算的初始值。如果把初始值设为100,计算:
reduce(f, [1, 3, 5, 7, 9], 100)
结果将变为125,因为第一轮计算是:
计算初始值和第一个元素:f(100, 1),结果为101。
任务
Python内置了求和函数sum(),但没有求积的函数,请利用recude()来求积:
输入:[2, 4, 5, 7, 12]
输出:2*4*5*7*12的结果
- ?不会了怎么办
reduce()接收的函数f需要两个参数,并返回一个结果,以便继续进行下一轮计算。
参考代码:
def prod(x, y): return x * yprint reduce(prod, [2, 4, 5, 7, 12])
0 0
- python中reduce()函数
- python中reduce()函数
- python中reduce函数
- python中map、filter、reduce 函数使用方法
- Python中reduce()函数的用法
- python中reduce函数的用法
- Python中filter、map、reduce函数
- python中的reduce函数
- Python reduce函数
- python中的reduce函数
- python中的reduce函数
- python reduce函数
- python中的reduce函数
- python中的reduce函数
- Python reduce函数
- Python-reduce函数
- python中的reduce()函数
- python的reduce()函数
- [生存志] 第13节 历代大事件概览 秦朝
- ibatis的批量处理
- 搭建odoo的开发调试环境http://www.veryopen.org/?p=3150
- html onclick="function"放入参数
- tjut 5943
- python中reduce()函数
- Servlet生命周期
- DNS原理及实战配置指南
- webpack配置热更新代码分享
- 模版笔记001 - 函数模版
- Linux服务器MySQL开启远程连接
- jQuery-学习积累-4
- 时钟周期 机器周期 指令周期
- Neural Networks for Machine Learning(系列)letcure 1