函数的返回值
1.什么是返回值
返回值就是函数返回给函数调用者的值(概念)
返回值就是return后面的值(语法)
返回值就是函数调用表达式的值(获取返回值)
2.return
1)什么是return
return是关键字,只能出现在函数体中
2)return作用
a.结束函数:执行函数体的时候,一旦遇到return函数直接结束
b.将数据返回给函数调用者 (将函数内部的数据传递到函数外部): return 需要返回的数据
说明:看一个函数的返回值是什么,就看执行函数的过程中有没有遇到return,如果遇到return
return后面的值就是函数的返回值
3)什么样的数据应该作为函数的返回值
初学者:如果执行完函数会产生新的数据,那么产生新的数据就可以返回,产生几个返回几个
return 返回值1, 返回值2
4)怎么获取函数返回值
获取函数调用表达式的值就是获取函数的返回值。(函数调用表达式:调用函数的语句)
3.函数的调用过程
1)回到函数调用的位置
2)传参,用实参给形参赋值(保证每个参数都有值)
3)执行函数体
4)执行完函数体,确定函数返回值
(函数结束:a.执行完函数体的最后一条语句 b.执行过程中遇到return)
确定返回值
5)回到函数调用的位置(这个时候函数调用的表达式的值才是函数的返回值),接着往后执行
调用函数:执行函数体,获取返回值
4.函数调用过程的内存变化
函数调用的过程其实是一个压栈的过程:每次调用函数的时候,系统会自动地在内存中专门为这个函数开辟一个内存空间,
用来保存在函数中声明的变量(形参也是声明在函数中的变量)。
当函数调用结束,这个内存区域自动释放
通过return返回数据
def st():
print('qwe')
def yt_sum(num1):
return st()
yt_sum(1)
匿名函数
1.匿名函数
匿名函数本质还是函数,普通函数中除了声明的 语法外
1)语法
lambda 参数列表:返回值
2)说明
lambda - 关键字,固定写法
参数列表 - 形参列表,以'参数名1,参数名2,···'
: - 固定写法
返回值 - 写任何有结果的表达式都可以
注意:匿名函数的函数体,只有一条语句,而且这条语句的结果就是函数的返回值(不需要return)
3)什么时候使用匿名函数
a.函数的功能代码一行就能实现
b.函数的功能不会重复使用
sum1 = lambda num1, num2: num1 + num2
print(type(sum1))
print(sum1(10, 20))
python三目运算符
python: 值1 if 条件语句 else 值2 - 如果条件语句的结果是True,整个表达式的结果是值1,否则是值2
c语言 - 条件语句?值1:值2 -如果条件语句的结果是True,整个表达式的结果是值1,否则是值2
num = 11
result = '偶数' if num % 2 == 0 else '奇数'
print(result)
练习:写一个匿名函数,两个数的最大值
max_num = lambda x, y: x if x > y else y
print(max_num(2, 4))
变量的作用域
1.什么是作用域
声明完变量后,这个变量能够使用的范围就是变量的作用域
2.全局变量和局部变量
1)全部变量:声明在函数或者类外面的变量都是全局变量
全局变量的作用域:从声明开始到整个文件结束
2)局部变量:声明在函数中的变量就是局部变量
局部变量的作用域:从声明开始到整个函数结束
a是全局变量
a = 100
x是全局变量
for x in range(4):
print(x)
局部变量
def func3(aa):
print(aa)
func3('avd')
3.global 和 nonlocal
这两个关键字只能在函数体中使用
1)global:在函数声明一个全局变量(去修改一个全局变量的值)
global 变量名
变量名 = 值
2)nonlocal:在局部的局部中修改局部变量的值
nonlocal 变量名
变量名 = 值
n1 = 100
def func4():
global n1
n1 = 200
print(n1)
func4()
print(n1)
def func5():
m = 10
def func55():
nonlocal m
m = 20
print('函数中的函数', m)
func55()
print('函数中', m)
func5()
递归函数
1.什么是递归函数:在函数中调用函数本身就是递归函数
循环能做的事情递归都可以做
1)怎么写递归函数
第一步:声明函数(和普通函数一样)
第二步:找临界值(函数结束的条件)
第三步:找关系
假设函数的功能已经实现,找f(n)与f(n-1)的关系
第四步:使用f(n-1)去实现f(n)的功能
2)总结:通过for或者while循环能做的事情就不要用递归做
用递归函数实现1+2+···+N
def sum1(n):
#1)找临界值
if n == 1:
return 1
#2)找关系
"""
sum1(n): 1+2+···+n sum1(n-1): 1+2+···+(n-1)
sum1(n) = sum1(n-1) +n
"""
return sum1(n-1) + n
print(sum1(100))
def sum2(n):
if n == 1:
print('*')
return
print(n*'*')
sum2(n-1)
sum2(5)
def sum_n(n):
if n ==1 or n == 2:
return 1
return sum_n(n-1) + sum_n(n-2)
print(sum_n(10))