網(wǎng)站首頁 編程語言 正文
高階函數(shù)除了可以接受函數(shù)作為參數(shù)外,還可以把函數(shù)作為結(jié)果值返回。
看代碼:
# -*- coding: utf-8 -*- # @File : 返回函數(shù)的高階函數(shù).py # @author: Flyme awei # @email : Flymeawei@163.com # @Time : 2022/8/21 14:48 def sum_fun(*args): def add_fun(): s = 0 for i in args: s += i return s return add_fun f = sum_fun(1, 2, 3, 4, 5, 6, 7, 8, 9) add = f() print(add) # 45
當(dāng)我們調(diào)用 sum_fun
時,返回的并不是求和結(jié)果,而是求和函數(shù) add_fun
, 將其賦值給f
,當(dāng)我們在調(diào)f
函數(shù)時才返回求和結(jié)果s
。
用filter函數(shù)來計算素數(shù)
??用
filter
來計算素數(shù)其中一個方法是埃氏篩法。
??給出要篩數(shù)值的范圍n
,找出以內(nèi)的素數(shù)。先用2
去篩,即把2
留下,把2
的倍數(shù)剔除掉;再用下一個質(zhì)數(shù),也就是3
篩,把3
留下,把3
的倍數(shù)剔除掉;接下去用下一個質(zhì)數(shù)5
篩,把5
留下,把5
的倍數(shù)剔除掉;不斷重復(fù)下去…
用Python高階函數(shù)來實(shí)現(xiàn)這個算法:
1、我們先寫一個生成器構(gòu)造一個從3開始的無限奇數(shù)序列,首先排除偶數(shù)。
def odd_num(): # 奇數(shù)生成器函數(shù) n = 1 while True: n += 2 yield n
2、寫一個篩選的函數(shù),這里使用了匿名函數(shù),返回判斷是否為可整除數(shù)
def un_divisible(n): # 判斷是否為可整除數(shù) return lambda x: x % n > 0
3、使用filter
來過濾,不斷返回素數(shù)的生成迭代
def primes(): # 素數(shù)生成器函數(shù) yield 2 it = odd_num() while True: n = next(it) yield n it = filter(un_divisible(n), it) # 過濾出不可以整除的數(shù)
4、判斷素數(shù)方法就產(chǎn)生了,這里需要手動結(jié)束一下
for i in primes(): # 打印小于100的素數(shù) if i < 100: print(i) else: break
高階函數(shù)實(shí)現(xiàn)打印小于100的素數(shù):
# -*- coding: utf-8 -*- # @File : 返回函數(shù)計算質(zhì)數(shù).py # @author: Flyme awei # @email : Flymeawei@163.com # @Time : 2022/8/21 15:17 # 得到所有的質(zhì)數(shù),打印小于100的所有的質(zhì)數(shù) # 最小的質(zhì)數(shù)是2, 質(zhì)數(shù):只能被1和它本身整除的數(shù) # 思路:先得到所有大于1的奇數(shù), --> 生成器,在把生成器中的所有元素過濾去掉: 那些可以被小于元素本身的質(zhì)數(shù)整除的數(shù) # 1.得到所有的大于1奇數(shù)的生 def odd_num(): n = 1 while True: n += 2 yield n def un_divisible(n): # 判斷是否能夠整除的函數(shù),n代表從生成器中拿到的一個大于1的質(zhì)數(shù) return lambda x: x % n > 0 # x是某一個奇數(shù),n:小于當(dāng)前x的一個質(zhì)數(shù) # 2.創(chuàng)建一個質(zhì)數(shù)的生成器,最小的質(zhì)數(shù)是2 def primes(): yield 2 n = odd_num() # g為大于1的奇數(shù)生成器 while True: x = next(n) g = filter(un_divisible(n), n) yield x for i in primes(): if i < 100: print(i, end=' ') else: break
第一段代碼生成了以3開始的奇數(shù)序列
第二段代碼自定義過濾函數(shù),包含匿名函數(shù),判斷值的取余是否能被整除
第三段代碼用來返回素數(shù),這里先返回一個2為素數(shù),因?yàn)榕紨?shù)都被排除了所
這就是100以內(nèi)的所有素數(shù):
總結(jié)?
原文鏈接:https://blog.csdn.net/m0_68744965/article/details/126451691
相關(guān)推薦
- 2023-01-28 Android?之Preference控件基本使用示例詳解_Android
- 2023-11-15 LaTeX調(diào)整圖片大小的方法;自動調(diào)整合適的大小
- 2022-08-15 form表單驗(yàn)證錯誤提示語太長無法全部展示的問題
- 2022-08-26 Python?Pandas中l(wèi)oc和iloc函數(shù)的基本用法示例_python
- 2022-05-27 go語言實(shí)現(xiàn)兩個協(xié)程交替打印_Golang
- 2022-09-05 Python?Behave框架學(xué)習(xí)_python
- 2022-09-01 MongoDB實(shí)現(xiàn)查詢、分頁和排序操作以及游標(biāo)的使用_MongoDB
- 2022-07-25 C/C++實(shí)現(xiàn)線性單鏈表的示例代碼_C 語言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支