函数与Lambda表达式
- 怎么给函数编写⽂档?
def MyFirstFunction(name):
"函数定义过程中name是形参"
print('传递进来的{0}叫做实参,因为Ta是具体的参数值!'.format(name))
help(MyFirstFunction)
# Help on function MyFirstFunction in module __main__:
# MyFirstFunction(name)
# 函数定义过程中name是形参
- 怎么给函数参数和返回值注解?
1)参数注解:在定义函数时,在参数列表内部的参数后面加上冒号和要传入的类型,写了参数注解也无法强制限定变量的类型,只能作为提示,来告知使用者应该传入什么类型的参数。如:
def accumlate(x:int, y:int):
return x*y
2)返回值注解就是在参数列表后面,冒号前面,增加一个 -> 后面接返回值的类型。如:
def accumlate(x:int, y:int) -> int:
return x*y
3. 闭包中,怎么对数字、字符串、元组等不可变元素更新。
采用nonlocal 关键字。
4. 分别根据每一行的首元素和尾元素大小对二维列表 a = [[6, 5], [3, 7], [2, 8]] 排序。(利用lambda表达式)
a = [[6, 5], [3, 7], [2, 8]]
x = sorted(a, key=lambda a: a[0], reverse=False)
print("按照首字符正序排列:",x)
x = sorted(a, key=lambda a: a[0], reverse=True)
print("按照首字符逆序排列:",x)
x = sorted(a, key=lambda a: a[1], reverse=False)
print("按照尾字符正序排列:",x)
x = sorted(a, key=lambda a: a[1], reverse=True)
print("按照尾字符逆序排列:",x)
- 利用python解决汉诺塔问题?
有a、b、c三根柱子,在a柱子上从下往上按照大小顺序摞着64片圆盘,把圆盘从下面开始按大小顺序重新摆放在c柱子上,尝试用函数来模拟解决的过程。(提示:将问题简化为已经成功地将a柱上面的63个盘子移到了b柱)
def Hannuota(n,a,b,c):
if n == 1:
print(str(a)+"移动到"+str(c))
else:
Hannuota(n-1, a, c, b)#a移动63个到b
Hannuota(1, a, b, c)#a移动1个到c
Hannuota(n-1, b, a, c)#b移动63个到c
Hannuota(64, 'a', 'b', 'c')