第四篇、函数和递归

高阶函数: 

规约函数

all(iterable):只要iterable的每个元素都是真,那么返回True,all([])为True

any(iterable)  :只要iterable中有元素为真,那么就返回True,any([]) False

python3中的reduce需要导入包from functools  import reduce

from functools import reduce
from operator import add
a=reduce(add,range(100))
print(a)

 

map filter reduce替代品列表推导,python3为生成器表达式

__call__:只要对象加括号就会执行,只要实现这个发那个发,任何对象都可以表现的像函数 

 

lambda匿名函数

里面可以用三元表达式

函数名=lambda 参数:return(或者三元表达式)

name=["a","c"]
res =map(lambda x: x if x=="a" else x+"1",name)
print(list(res))

['a', 'c1']

 

递归:

python2.7中:

def fib_seq(n):
     if n < 2:
        return n
     a,b = 1,0
     for i in range(n-1):
        a,b = a+b,a
     return a
print(fib_seq(10)

在python3中有更快的递归方法:

from numba import jit
@jit
def fib_seq_numba(n):
    if n<2:
        return n
    (a,b)=(1,0)
    for i in range(n-1):
        (a,b)=(a+b,a)
        return a

print(fib_seq_numba(10))

  

性能比cpython快16000倍

 

posted @ 2017-03-05 20:16  pyrene  阅读(173)  评论(0编辑  收藏  举报