Day10_Summary

函数基础

返回值

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)
(怎么确定返回值: 看执行函数的过程中有没有遇到return,如果遇到return,return后面的值就是函数的返回值)

5)回到函数调用位置,接着往后执行

调用函数: 执行函数体,获取返回值

4.函数调用过程的内存变化

函数调用的过程是一个压栈的过程:每次调用函数的时候,系统都会自动地在内存中专门为这个函数开辟一个内存空间,用来保存在函数中声明的变量(形参也是声明在函数中的变量)当函数调用结束,这个内存区域会自动释放

def test_sum(num1, num2):
    return num1 + num2


test_sum(32, 23)
print(test_sum(100, 23))
list1 = [test_sum(3, 2), test_sum(32, 1), test_sum(231, 456)]
print(list1)

匿名函数

1.匿名函数

匿名函数本质还是函数, 普通函数中除了声明的语法其他都适用于匿名函数

1)语法

lambda 参数列表:返回值

2)说明

lambda - 关键字,固定写法
参数列表 - 形参列表,以'参数名1, 参数名2,...'
: - 固定
返回值 - 写任何有结果的表达式都可以
注意:匿名函数的函数体,只有一条语句,而且这条语句的结果就是函数的返回值(不需要return)

3)什么时候使用匿名函数

a.函数的功能一行代码就可以实现
b.函数的功能不会重复使用
练习1:写一个函数,求两个数的和

sum1 = lambda num1, num2: num1 + num2

练习2:写一个匿名函数,求两个数中最大值

max1 = lambda num1, num2: '最大值:%d' % num1 if num1 > num2 else '最大值:%d' % num2

python中的三目运算符:

c语言 - 条件语句?值1:值2
python - 值1 if 条件语句 else 值2

作用域

1.什么是作用域

声明完变量后,这个变量能够使用的范围就是变量的作用域

2.全局变量和局部变量

1)全局变量: 声明在函数或者类外面的变量都是全局变量

全局变量的作用域: 从声明开始到整个文件结束

2)局部变量: 声明在函数中的变量就是局部变量

局部变量的作用域:从声明开始到整个函数结束

3.global和nonlocal

这两个关键字只能在函数体中使用

1)global: 在函数中声明一个全局变量(或者修改一个全局变量的值)

global 变量名
变量名 = 值

2)nonlocal: 在函数中的函数中声明一个局部变量(或修改)

nonlocal 变量名
变量名 = 值

n1 = 100


def fun1():
    global n1
    n1 = 200
    print(n1)


fun1()
print(n1)
print(fun1())

递归函数

1.什么是递归函数: 在函数中调用函数本身,这样的函数就是递归函数

循环能做的事情递归都可以做

1)怎么写递归函数

第一步: 声明函数(和普通函数一样)
第二步: 找临界值(函数结束的条件)
第三步: 找关系
假设函数f的功能已经实现了, 找f(n)和f(n-1)的关系
第四步: 使用f(n-1)去实现f(n)的功能

2)总结: 通过for或者while能做的事情就不要用递归去做

练习1:用递归实现1 + 2 + 3 + ... + N

def sum1(n):
    if n == 1:
        return 1
    return sum1(n-1) + n

练习2:斐波那契数列

def fibonacci(n):
    if n <= 2:
        return 1
    return fibonacci(n-1) + fibonacci(n-2)

你可能感兴趣的:(Day10_Summary)