递归,二分法,匿名函数-创新互联
递归调用:在调用一个函数的过程中,直接或者间接又调用了函数本身,称之为递归调用。
递归的必备的两阶段:一:递推 二:回溯
def foo():
print('abc')
foo()
foo()
import sys
print(sys.getrecursionlimit())
sys.getrecursionlimit(200) #设置递归次数
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] #从小到大排列的数字列表
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拉链函数
g='wordwrod'
h=[1,2,3,4]
f=zip(g,h)
print(list(f))
匿名函数:lambda 没有函数调用名称,只生成一次存在于内存地址。
def foo(x,y):
return x+y
foo(1,2)
同:
print(lambda x,y:x+y)(1,2)
匿名函数的使用:
#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 排序,默认按照首字母排序
sab={
'a':1223
'b':12345
'c':34567
'd':345
}
print(sorted(sab,key=lambda k:sab[k],reverae=Ture)) #reverae=Ture反转
#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) #设定初始值,100为初始值
#filter 过滤
names=['df_bb','gh_bb','jk_bb']
g=filter(lambda x:x.endswith('bb'),names)
print(list(g))
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
在卧龙等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站制作、做网站 网站设计制作定制网站,公司网站建设,企业网站建设,品牌网站制作,全网整合营销推广,外贸营销网站建设,卧龙网站建设费用合理。文章名称:递归,二分法,匿名函数-创新互联
文章网址:http://pcwzsj.com/article/jdodd.html