################################高阶函数
1.sorted函数
排序也是在程序中经常用到的算法。 无论使用冒泡排序还是快速排序,排序的核心是比较两个元素的大小。通常规定如下:
x < y, return -1
x == y, return 0
x > y, return 1
例1,倒序输出给定数字:
例2。给字符串排序
2.函数作为返回值
高阶函数除了可以接受函数作为参数外,还可以把函数作为结果值返回。
例1.计算给定数字的和
例2.计算1-3的平方
3.匿名函数
•当我们在传入函数时,有些时候,不需要显式地定义函数,直接传入匿名函数更方便。
•关键字 lambda 表示匿名函数,冒号前面的 x 表示函数参数
•匿名函数有只能有一个表达式,不用写 return ,返回值就是该表达式的结果。
•因为匿名函数没有名字,不必担心函数名冲突。 此外,匿名函数也是一个函数对象,也可以把匿名函数赋值给一个变量,再利用变量来调用该函数;
•也可以把匿名函数作为返回值返回
# 匿名函数 # 优点:1)匿名函数不需要函数名,可以避免函数名的冲突 # 2)匿名函数可以跳过函数分配栈空间 # 3)匿名函数可以赋值给一个变量,需要运行时,变量名()
# 书写规则:lambda:关键字 ‘:’之前:传入的参数,‘:’之后:返回值 # 传值:必选参数
# print map(lambda x:x*x,range(1,11))例.利用匿名函数实现四则运算# 传值:默认参数 # f = lambda x,y=2:x**y # print f(2,3) # print f(2) # 传值:可变参数 # f = lambda *x:map(lambda x:x*x,x) # print f(1,2,3,4) # 传值:关键字参数 # f = lambda **kwargs:kwargs.items() # print f(name='fentiao',age=5)
4.装饰器
• 装饰器就是用来装饰函数。
• 想要增强原有函数的功能;
• 但不希望修改now()函数的定义;
• 在代码运行期间动态增加功能的方式;
• 定义的装饰器实质是返回函数的高阶函数
例1.计算函数运行时间
例2.将函数运行时间的结果导入文件