Python3之高阶函数filter
Python内建的filter()函数用于过滤序列
和map()一样,filter()也接收一个函数和一个序列。和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是True还是False决定保留还是丢弃改元素
例如,在一个list中,删掉偶数,保留奇数
>>> def is_odd(n):
... return n%2==1
...
>>> list(filter(is_odd,[1,2,3,4,5,6,7]))
[1, 3, 5, 7]
把序列作为参数传递至函数is_odd()如果参数为奇数则返回True则保留,如果参数为偶数则返回False则不保留
把一个序列中的空字符删除
>>> def is_empty(s):
... return s and s.strip()
>>> list(filter(is_empty,['1','',None,' ','zhangs']))
['1', 'zhangs']
函数is_empty返回为s and s.strip()及字符不为空则返回为True否则为False
注意到filter()
函数返回的是一个Iterator
,也就是一个惰性序列,所以要强迫filter()
完成计算结果,需要用list()
函数获得所有结果并返回list。
用filter求素数,素数定义:指整数在一个大于1的自然数中,除了1和此整数自身外,没法被其他自然数整除的数
首先列出从2开始的自然数构成一个无限序列:
2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20...
取序列的第一个数2一定是一个素数,然后用2筛选序列能被2整除的去掉,不能被2整除的保留
2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20...
保留下来的序列为
3,5,7,9,11,13,15,17,19...
取新序列的第一个数3一定是一个素数,然后用3筛选序列能被3整除的数去掉,不能被3整除的保留
3,5,7,9,11,13,15,17,19...
保留下来的序列为
5,7,11,13,17,19...
然后去新序列的第一个数5一定是一个素数 ,筛选,以此类推不断筛选下去就能得到所有素数
第一个素数是2 第一次筛选就可以把所有偶数剔除
定义一个已3开始的奇数序列
>>> def _odd_iter():
... n=3
... while True:
... yield n
... n=n+2
...
定义_odd_iter()函数,函数定义n初始值为3 ,ywhile True 无限循环,yield生成器返回序列第一个数为3然后n递增2,以此类推
输出以3开始的奇数序列,因为_odd_iter()是一个无限序列所有需要设置一个退出循环的条件
>>> for n in _odd_iter():
... if n<100:
... print(n)
... else:
... break
输出以3开始小于100的奇数
定义筛选函数不能被整除
>>> def _not_divislibe(n):
... def f(x):
... return x%n>0
... return f
这里函数调用返回的还是函数,需要在调用的时候才执行,例如调用
fun1=_not_divisible(2)
相当于调用函数后参数n=2返回函数fun1=f,返回函数不会立即执行需要在调用的时候才执行,调用的时候加参数x判断x能否整除n,如果可以整除则x%n==0 不满足条件x%n>0所以返回False,不能整除则返回为True
#2可以被4整除返回为False
>>> fun1(4)
False
#2不能被5整除 5%2=1>0
>>> fun1(5)
True
关于返回函数查看https://www.cnblogs.com/minseo/p/11064421.html
最后定义一个生成器primes()不断返回素数
>>> def primes():
#先返回第一个素数2
... yield 2
#把从3开始的无限奇数序列赋值给序列it
... it=_odd_iter()
... while True:
#返回序列的第一个数一定是素数
... n=next(it)
... yield n
#把第一个数当成被除数,使用序列如果不能被整除则保留下来
... it=filter(_not_divislibe(n),it)
设置一个条件打印出来,打印出小于100的素数
>>> for n in primes():
... if n<100:
... print(n)
从2开始构建自然数序列写法
primes()
#构建以2开始的自然数序列
def _natural_iter():
n=2
while True:
yield n
n=n+1 #定义不能被整除函数
def _not_divisible(n):
return lambda x:x%n>0 #定义素数函数
def primes():
#把从2开始的自然数赋值给序列it
it=_natural_iter()
while True:
#去序列第一个数一定是素数作为生成器的返回
n=next(it)
yield n
#把序列的第一位数作为被除数依次使用后面的数如果能被整除则删除,不能被整除则保留
#例如第一次使用filter过滤及把偶数过滤掉剩下的为从3开始的所有奇数
it=filter(_not_divisible(n),it) for n in primes():
if n<100:
print(n)
else:
break
练习:回数是至从左往右读和从右往左都都是一样的数,例如1,11,121,12321.利用filter筛选出回数
思路:定义一个函数传递的参数为整数n,把n转换成字符串,然后反转与初始字符串对比,如果一样就代表是回数
is_palindrome.py
def is_palindrome(n):
#str(n)把整数转换成字符串使用切片法反转
#例如s='123'则s[::-1]='321'
#如果反转后与反转前是一致则返回True
return str(n)==str(n)[::-1] #打印1-1999之间所有回数
print(list(filter(is_palindrome,range(1,2000))))
结果
[1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 22, 33, 44, 55, 66, 77, 88, 99, 101, 111, 121, 131, 141, 151, 161, 171, 181, 191, 202, 212, 222, 232, 242, 252, 262, 272, 282, 292, 303, 313, 323, 333, 343, 353, 363, 373, 383, 393, 404, 414, 424, 434, 444, 454, 464, 474, 484, 494, 505, 515, 525, 535, 545, 555, 565, 575, 585, 595, 606, 616, 626, 636, 646, 656, 666, 676, 686, 696, 707, 717, 727, 737, 747, 757, 767, 777, 787, 797, 808, 818, 828, 838, 848, 858, 868, 878, 888, 898, 909, 919, 929, 939, 949, 959, 969, 979, 989, 999, 1001, 1111, 1221, 1331, 1441, 1551, 1661, 1771, 1881, 1991]
字符串反转参考:https://www.cnblogs.com/minseo/p/11065920.html
Python3之高阶函数filter的更多相关文章
- 高阶函数 filter map reduce
const app=new Vue({ el:'#app', data:{ books:[{ id:1, name:"算法导论", data: '2006-1', price:39 ...
- js高阶函数filter、map、reduce
// 高阶函数 filter/map/reduce // filter中的回调函数有一个要求:必须返回一个boolean值, // 当返回true时,函数内部会自动将这次回调的 n 加入到新的数组中 ...
- Python 学习——高阶函数 filter 和 sorted
filter filter函数顾名思义,筛选,通过调用函数进行筛选序列中的满足函数的子项 以实例来说话: 过滤一个序列中所有的偶数,保留奇数 另如下,过滤掉一个序列中的所有空格以及空字符等信息 可以知 ...
- python之高阶函数filter
原文 Python内建的filter()函数用于过滤序列. 和map()类似,filter()也接收一个函数和一个序列.和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返 ...
- 高阶函数:filter()
Python内建的filter()函数用于过滤序列. 和map()类似,filter()也接收一个函数和一个序列.和map()不同的是,filter()把传入的函数依次作用于每个元素,然后根据返回值是 ...
- python学习笔记1 -- 函数式编程之高阶函数 filter
filter 函数用于过滤序列,与map 和reduce函数类似,作为高阶函数,他们也是同样的使用方法,filter(参数1, 参数2),参数1是一个函数,而参数2是一个序列. filter的作用是根 ...
- JavaScript(1)高阶函数filter、map、reduce
前言 需求:有这样一个数组[10, 20, 110, 200, 60, 30, 40] 1.筛选出数组中小于100的元素 2.将筛选出的每个元素的值x2 3.完成第2步之后,将数组中的所有元素加起来 ...
- Python3之高阶函数sorted
排序算法 Python内置的sorted()函数可以对list进行排序 >>> sorted([36,5,-12,9,-21]) [-21, -12, 5, 9, 36] 此外,so ...
- js 高阶函数 filter
filter用于过滤array中的一些值,通过带入的函数返回的ture 或false 保留或去除,返回一个新的array filter 使用演示:判断筛选出array中的素数: //判断素数自定义函数 ...
随机推荐
- 41、扩展原理-ApplicationListener用法
41.扩展原理-ApplicationListener用法 ApplicationListener 监听容器中发布的事件.事件驱动模型开发: public interface ApplicationL ...
- 使用$.getJSON("xx.json" ,function(data){ console.logy(data); })在本地获取 json数据
使用 $.getJSON() 在本地获取 json数据 默认在谷歌,火狐等其他浏览器,不允许在本地获取服务器数据 所以不能在本地中使用 但是可以IE 11 中又可以使用,所以,测试时建议在IE浏览器 ...
- 最短路--Dijkstra
Dijkstra--单源最短路 算法思想 主要记住这句话:每次选择没有被访问过的,并且dis最小的点,加入集合,更新dis 模板 int dis[maxn],vis[maxn]; //距离,标记 vo ...
- 洛谷 P2119 魔法阵 题解
Analysis 这道题也是考试题,我也依然打了个n三次方暴力.正解是先枚举差,再枚举c和d,a和b用乘法原理优化,这样就能大大减少时间. #include<iostream> #incl ...
- MongoDB 查看chunk块大小
使用mongo shell连到mongos执行命令:AllChunkInfo("dbname.cellname",true) 点击(此处)折叠或打开 AllChunkInfo = ...
- Centos7的rabbitmq镜像集群
1.下载RabbitMQ vim /etc/hosts10.10.21.197 rabbit110.10.21.198 rabbit2 #分别命名hostname rabbit1hostname ra ...
- Mac cpu过高问题分析及解决
1.mds.mds_stores.mdworker 关闭: sudo mdutil -a -i off 打开: sudo mdutil -a -i on
- 前端武器库之DOM练习
1.模态对话框 <!DOCTYPE html> <html lang="en"> <head> <meta charset="U ...
- angularJs driective指令小实例
做一个下拉菜单,体会指令各参数的作用 html代码 <script type="text/ng-template" id="mydropdown.html" ...
- BAT资深工程师由浅入深分析Tp5&Tp6底层源码☆
第1章 课程简介 本章主要让大家知道本套课程的主线, 导学内容,如何学习源码等,看完本章要让小伙伴觉得这个是必须要掌握的,并且对加薪有很大的帮助. 第2章 [TP5灵魂]自动加载Loader 深度分析 ...