热门问题
时间线
聊天
视角

Filter (高阶函数)

来自维基百科,自由的百科全书

Remove ads

函数式编程中,过滤器(filter)是一个高阶函数,它按某种次序处理一个数据结构(通常是列表),来产一个新的数据结构,它精确的包含最初数据结构中给定谓词英语Predicate (mathematical logic)对其返回布尔值true的那些元素。

定义

Python

Python中,filter在说明文档中的语法是filter(function,iterable)

可以用如下办法用列表推导式实现

output = [x for x in iterable if function]

在Python2中filter返回一个list,而在Python3中filter返回一个迭代器对象。

Haskell

Haskell中,filter可以如下这样实现:

filter :: (a -> Bool) -> [a] -> [a]
filter _ []     = []
filter p (x:xs) = [x | p x] ++ filter p xs

这里的[]指示空列表,++是列表串接算子,而[x | p x]指示有条件持有一个值x的列表,如果条件p x成立(求值为True)。

例子

Haskell中代码例子

filter even [1..10]

求值得到列表2, 4, …, 10,这是通过应用谓词even到整数列表1, 2, …, 10的按原次序的所有元素,并建立谓词对其返回布尔值true的那些元素的一个新的列表,因而给出的是只包含原列表的偶数成员的一个列表。反过来,代码例子:

filter (not . even) [1..10]

求值得出列表1, 3, …, 9,这是通过搜集整数列表1, 2, …, 10中,谓词对其返回布尔值false的那些元素(这里的.函数复合算子英语Function composition (computer science))。

Python3中代码例子

>>>print(list(filter(lambda x:x % 2 == 0,[1,2,3,4,5,6,7,8])))  #输出偶数
[2, 4, 6, 8]

可视的例子

下面是一个过滤器过程的每个步骤的可视演示,对于整数列表X = [0, 5, 8, 3, 2, 1]依据函数:

这个函数表达了如果是偶数,则返回值是,否则是,这是谓词。

Thumb
在应用过滤器在列表上的时候的处理步骤的演示
Remove ads

语言比较

过滤器是很多编程语言的标准函数,比如Haskell[1]OCaml[2]Standard ML[3]Erlang[4]Common Lisp提供了函数remove-ifremove-if-not[5]Scheme实现要求英语Scheme Requests for Implementation(SRFI)1提供了Scheme语言过滤器的一个实现[6]C++提供了算法英语Algorithm (C++)remove_if(可变)和remove_copy_if(不可变);C++11补充提供了copy_if(不可变)[7]Smalltalk为搜集提供了select:方法。过滤器还可以在支持列表推导式的语言中使用它来实现。

更多信息 语言, Filter ...
Remove ads

变体

过滤器建立它的结果而不修改最初的列表。很多编程语言还提供破坏性修改列表实际参数的有更快性能的变体。过滤器的其他变体(比如Haskell dropWhile[18]partition[19])也是常见的。常见的纯函数式编程语言内存优化英语Program optimization是拥有输入列表并过滤结果共享最长尾部。

参见

引用

Loading related searches...

Wikiwand - on

Seamless Wikipedia browsing. On steroids.

Remove ads