溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

遞歸,二分法,匿名函數(shù)

發(fā)布時(shí)間:2020-08-02 10:24:10 來源:網(wǎng)絡(luò) 閱讀:396 作者:期待美好 欄目:編程語言
遞歸調(diào)用:在調(diào)用一個(gè)函數(shù)的過程中,直接或者間接又調(diào)用了函數(shù)本身,稱之為遞歸調(diào)用。
遞歸的必備的兩階段:一:遞推 二:回溯

def foo():
    print('abc')
    foo()
foo()

import sys
print(sys.getrecursionlimit())
sys.getrecursionlimit(200)  #設(shè)置遞歸次數(shù)
print(sys.getrecursionlimit())

def age(n):
    if n == 1:
        return 18
    return age(n-1) + 2
print(age(5))

g=[1,[2,[3,[4,[5,[6,[7]]]]]]]
def foo(g):
    for i in g:
        if type(i) is list:
            foo(g)
        else:
            print(i)
foo(g)

二分法:
g=[1,2,3,4,5,6,7,8,10,13,455,678,990,11111] #從小到大排列的數(shù)字列表
def  foo(g,numl):
    print(g)
    if len(g) == 0:
        print("it is not")
        return 
    fdoml=len(g) // 2
    if numl  > g[fdoml]:
        foo(g[fdoml+1:],numl)
    elif numl < g[fdoml]:
        foo(g[0:fdoml],numl)
    else:
        print('find it')
foo(g,678)

#zip拉鏈函數(shù)
g='wordwrod'
h=[1,2,3,4]
f=zip(g,h)     
print(list(f))

匿名函數(shù):lambda 沒有函數(shù)調(diào)用名稱,只生成一次存在于內(nèi)存地址。
def foo(x,y):
    return x+y
foo(1,2)
同:
print(lambda x,y:x+y)(1,2) 

匿名函數(shù)的使用:
#max   最大
sab={
'a':1223
'b':12345
'c':34567
'd':345
}

def foo(k):
    return sab[k]

print(max(sab,key=foo))  

同:
print(max(sab,key=lambda k:sab[k])) 

#min  最小
print(min(sab,key=lambda k:sab[k])) 

#sorted  排序,默認(rèn)按照首字母排序
sab={
'a':1223
'b':12345
'c':34567
'd':345
}

print(sorted(sab,key=lambda k:sab[k],reverae=Ture))  #reverae=Ture反轉(zhuǎn)

#map  映射
names=['df','gh','jk']
u=[]
for i in names:
    res='%s_bb' %names
    u.append(res)
print(u)

同:
g=map(lambda i:'%s_bb' %i,names)
print(list(g))

#reduce   合并
from functcols import reduce  
reduce(lambda x,y:x+y ,range(1,101))
reduce(lambda x,y:x+y ,range(1,101),100)   #設(shè)定初始值,100為初始值

#filter  過濾
names=['df_bb','gh_bb','jk_bb']
g=filter(lambda x:x.endswith('bb'),names)
print(list(g))
向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI