日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無(wú)先后,達(dá)者為師

網(wǎng)站首頁(yè) 編程語(yǔ)言 正文

Python函數(shù)式編程之返回函數(shù)實(shí)例詳解_python

作者:北極的三哈 ? 更新時(shí)間: 2022-11-15 編程語(yǔ)言

高階函數(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 時(shí),返回的并不是求和結(jié)果,而是求和函數(shù) add_fun , 將其賦值給f,當(dāng)我們?cè)谡{(diào)f函數(shù)時(shí)才返回求和結(jié)果s

用filter函數(shù)來(lái)計(jì)算素?cái)?shù)

??用filter來(lái)計(jì)算素?cái)?shù)其中一個(gè)方法是埃氏篩法。
??給出要篩數(shù)值的范圍n,找出以內(nèi)的素?cái)?shù)。先用2去篩,即把2留下,把2的倍數(shù)剔除掉;再用下一個(gè)質(zhì)數(shù),也就是3篩,把3留下,把3的倍數(shù)剔除掉;接下去用下一個(gè)質(zhì)數(shù)5篩,把5留下,把5的倍數(shù)剔除掉;不斷重復(fù)下去…

用Python高階函數(shù)來(lái)實(shí)現(xiàn)這個(gè)算法:

1、我們先寫(xiě)一個(gè)生成器構(gòu)造一個(gè)從3開(kāi)始的無(wú)限奇數(shù)序列,首先排除偶數(shù)。

def odd_num():  # 奇數(shù)生成器函數(shù)
    n = 1
    while True:
        n += 2
        yield n

2、寫(xiě)一個(gè)篩選的函數(shù),這里使用了匿名函數(shù),返回判斷是否為可整除數(shù)

def un_divisible(n):  # 判斷是否為可整除數(shù)
    return lambda x: x % n > 0

3、使用filter來(lái)過(guò)濾,不斷返回素?cái)?shù)的生成迭代

def primes():  # 素?cái)?shù)生成器函數(shù)
    yield 2
    it = odd_num()
    while True:
        n = next(it)
        yield n
        it = filter(un_divisible(n), it)  # 過(guò)濾出不可以整除的數(shù)

4、判斷素?cái)?shù)方法就產(chǎn)生了,這里需要手動(dòng)結(jié)束一下

for i in primes():  # 打印小于100的素?cái)?shù)
    if i < 100:
        print(i)
    else:
        break  

高階函數(shù)實(shí)現(xiàn)打印小于100的素?cái)?shù):

# -*- coding: utf-8 -*-
# @File  : 返回函數(shù)計(jì)算質(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ù), --> 生成器,在把生成器中的所有元素過(guò)濾去掉: 那些可以被小于元素本身的質(zhì)數(shù)整除的數(shù)

# 1.得到所有的大于1奇數(shù)的生
def odd_num():
    n = 1
    while True:
        n += 2
        yield n

def un_divisible(n):  # 判斷是否能夠整除的函數(shù),n代表從生成器中拿到的一個(gè)大于1的質(zhì)數(shù)
    return lambda x: x % n > 0  # x是某一個(gè)奇數(shù),n:小于當(dāng)前x的一個(gè)質(zhì)數(shù)

# 2.創(chuàng)建一個(gè)質(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開(kāi)始的奇數(shù)序列
第二段代碼自定義過(guò)濾函數(shù),包含匿名函數(shù),判斷值的取余是否能被整除
第三段代碼用來(lái)返回素?cái)?shù),這里先返回一個(gè)2為素?cái)?shù),因?yàn)榕紨?shù)都被排除了所

這就是100以內(nèi)的所有素?cái)?shù):

總結(jié)?

原文鏈接:https://blog.csdn.net/m0_68744965/article/details/126451691

欄目分類(lèi)
最近更新