Python基础七(函数)

  • 函数
  • 1. 函数的返回值
  • 2. 文档字符串
  • 3. 函数的作用域
  • 4. 命名空间
  • 5. 递归函数


函数

1. 函数的返回值

  • 返回值就是函数执行以后返回的结果
  • 通过return来指定函数的返回值
  • return后面可以跟任意对象,返回值甚至可以是一个函数
  • 对于返回值来说。不写return *** 或只写了一个return,返回的都是None
def fun1():
    def fun2():
        pass
#fun1()() == fun2()
#fun1() == fun2

2. 文档字符串

  • help()是Python中内置函数,通过help()函数可以查询Python中函数的用法
  • 在定义函数时,可以在函数内部编写文档字符串,文档字符串就是对函数的说明

3. 函数的作用域

  • 作用域(scope)
  • 作用域指的是变量生效的区域
  • 在Python中一共有两种作用域
  • 全局作用域
  • 全局作用域在程序执行时创建,在程序执行结束时销毁
  • 所有函数以外的区域都是全局作用域
  • 在全局作用域中定义的变量,都是全局变量,全局变量可以在程序的任意位置进行访问
  • 函数作用域
  • 函数作用域在函数调用时创建,在调用结束时销毁
  • 函数每调用一次就会产生一个新的函数作用域
  • 在函数作用域中定义的变量,都是局部变量,它只能在函数内部被访问

如果函数内部的参数想被函数外部调用,可以用global设为全局变量

def fun1():
    global a
    a = 10
    def fun2():
        print(a)
    fun2()
fun1()
print(a)

4. 命名空间

  • 命名空间实际上就是一个字典,是一个专门用来存储变量的字典
  • locals()用来获取当前作用域的命名空间
  • 如果在全局作用域中调用locals()则获取全局命名空间,如果在函数作用域中调用locals()则获取函数命名空间
  • 返回值是一个字典
  • 获取全局作用域的命名空间用globals()

5. 递归函数

  • 递归是解决问题的一种方式,它的整体思想,是将一个大问题分解为一个个的小问题,直到问题无法分解时,在去解决问题
  • 递归式函数有2个条件
  • 1.基线条件 问题可以被分解为最小问题,当满足基线条件时,递归就不执行了
  • 2.递归条件 可以将问题继续分解的条件
def fun(n):
    #基线条件:被分解为最小的问题,满足基线条件再去解决问题
    if n == 1:
        return 1
    #递归条件:将问题继续分解的条件
    return n * fun(n-1)
r = fun(10)
print(r)

递归练习:

求任意数字的任意次幂运算

def fun(n,m):
    if m == 1:
        return 10
    return n * fun(n,m-1)
r = fun(10,5)
print(r)

判断是否回音字符串

def fun(s):
    if len(s) < 2:
        return True
    elif s[0] != s[-1]:
        return False
    return fun(s[1:-1])
s = input("请输入一个字符串:")
if len(s) < 2:
    print("字符串太短")
else:
    print(fun(s))

实战演练:

  1. 用函数实现一个判断用户输入的年份是否是闰年的程序
    1.能被400整除的年份
    2.能被4整除,但是不能被100整除的年份
    以上2种方法满足一种即为闰年
def fun(y):
    if y%400 == 0:
        print(f"{y}年是闰年")
    elif y%4 == 0 and y%100 != 0:
        print(f"{y}年是闰年")
    else:
        print(f"{y}年不是闰年")
fun(int(input("请输入一个年份:")))
  1. 猴子吃桃问题(递归):
    猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了,求第一天共摘了多少桃子?
def fun(d):
    if d == 1:
        return 1
    else:
        return (fun(d-1)+1)*2
print(fun(10))