内容简介:Python|高阶函数
01
函数名也是变量!
abs(-100)
abs()
这个函数,完全可以把函数名 abs
看成变量,它指向一个计算绝对值的函数!
因此,函数名其实就是指向函数的变量,也就是说,变量可以指向函数。
f = abs
f(-10)
10
02
高阶函数
既然变量f可以指向函数,并且函数的参数能接收变量,那么一个函数就可以接收另一个函数作为参数,这种函数就称之为高阶函数。
def minus(x, y, f):
return f(x) - f(y)
minus就是高阶函数,因为其参数f,指向了函数。
当我们调用 minus(-10,4,abs)时,根据函数定义,可以推导计算过程如下:
x = -10
y = 4
f = abs
f(x) + f(y) ==> abs(-10) - abs(4) ==> 6
return 6
03
Map
map()
传入的第一个参数是
f
, map
将f依次作用到序列的每个元素,并把结果作为新的Iterator
返回。
def f(x):
return x * x
如果不用map,需要这么写:
L = []
for n in [1, 2, 3, 4, 5, 6, 7, 8, 9]:
L.append(f(n))
用map一行代码搞定:list(map(f, [1, 2, 3, 4, 5, 6, 7, 8, 9]))
另外一个map例子:
list(map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9]))
结果:
['1', '2', '3', '4', '5', '6', '7', '8', '9']
再看一个map例子:
def char2num(s):
digits = {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}
return digits[s]
print(list(map(char2num,"13579"))) #注意“13579”是个序列
结果:
[1, 3, 5, 7, 9]
04
Reduce
reduce把f作用在一个序列[x1, x2, x3, ...]上,f必须接收两个参数。
reduce把结果继续和序列的下一个元素做累积计算,其效果就是:
reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)
from functools import reduce
#reduce的参数f函数,f必须接受两个参数
def fn(x, y):
return x * 10 + y
reduce(fn, [2, 4, 6, 7, 9])
结果:
24679
05
和Reduce
def str2num(s):
return reduce(fn, map(char2num, s))
print(str2num('213579'))
结果:
213579
解释:map作用将序列s中每一个字符转化为num,返回一个Iterator对象,reduce的参数fn将这个Iterator对象转化为对应的整数表示。
Map完成了数据拆分,Reduce化简合并数据。
《实例》阐述算法,通俗易懂,助您对算法的理解达到一个新高度。包含但不限于:基本算法,机器学习,深度学习,Kaggle实战,Spark和Tensorflow等。期待您的到来!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- Python第六章-函数06-高阶函数
- JS 函数式编程思维简述(二):高阶函数
- Python小世界:匿名函数、高阶函数、推导式
- Javscript 高阶函数(上)
- 【重温基础】21.高阶函数
- 高阶函数的使用
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据结构与算法JavaScript描述
[美] Michael McMillan / 王群锋、杜 欢 / 人民邮电出版社 / 2014-8 / 49.00元
通过本书的学习,读者将能自如地选择最合适的数据结构与算法,并在JavaScript开发中懂得权衡使用。此外,本书也概述了与数据结构与算法相关的JavaScript特性。 本书主要内容如下。 数组和列表:最常用的数据结构。 栈和队列:与列表类似但更复杂的数据结构。 链表:如何通过它们克服数组的不足。 字典:将数据以键-值对的形式存储。 散列:适用于快速查找和检索。......一起来看看 《数据结构与算法JavaScript描述》 这本书的介绍吧!