Lesson-9 函数(中)

1.函数的返回值

  • return 后⾯可以跟任意对象,返回值甚⾄可以是⼀个函数

2.文档字符串

  • help()
    • Python中内置函数,通过help()函数可以查询Python中函数的⽤法
    • 在定义函数时,可以在函数内部编写⽂档字符串,⽂档字符串就是对函数的说明
def xxx(a,b,c):
    """
    这是文档字符串创建方法:
    打出6个双引号,然后在第三个双引号处回车
    :param a:
    :param b:
    :param c: 
    :return:
    """
    return a,b,c

help(xxx)   #查看文档字符串的语法

3.函数的作⽤域

  • 作⽤域指的是变量⽣效的区域
  • 在Python中⼀共有两种作⽤域
    • 全局作⽤域
      • 全局作⽤域在程序执⾏时创建,在程序执⾏结束时销毁
      • 所有函数以外的区域都是全局作⽤域
      • 在全局作⽤域中定义的变量,都是全局变量,全局变量可以在程序的任意 位置进⾏访问
    • 函数作⽤域
      • global 将函数内变量转化为全局变量
      • 函数作⽤域在函数调⽤时创建,在调⽤结束时销毁
      • 函数每调⽤⼀次就会产⽣⼀个新的函数作⽤域
      • 在函数作⽤域中定义的变量,都是局部变量,它只能在函数内部被访问

4.命名空间

-命名空间实际上就是⼀个字典,是⼀个专⻔⽤来存储变量的字典

  • locals() ⽤来获取当前作⽤域的命名空间
    • 如果在全局作⽤域中调⽤locals()则获取全局命名空间
    • 如果在函数作⽤域中 调⽤locals()则获取函数命名空间
    • 返回值是⼀个字典
  • global()在函数内获取全局作用域的命名空间

5.递归函数

  • 递归是解决问题的⼀种⽅式,它的整体思想,是将⼀个⼤问题分解为⼀个个 的⼩问题,直到问题⽆法分解时,在去解决问题
  • 递归式函数有2个条件
      1. 基线条件 问题可以被分解为最⼩问题,当满⾜基线条件时,递归就不 执⾏了
      1. 递归条件 可以将问题继续分解的条件
# 递归函数的两个条件
# 1. 基线条件  问题可以被分解为最小的问题,当满足基线条件的时候,再去解决问题  (设定的最大递归深度)
# 2. 递归条件  将问题继续分解的条件
# 10!            n!          fun(n)   是求n的阶乘的函数
# 10! = 10 * 9!  n*(n-1)!    n * fun(n-1)   求n-1的阶乘的函数
# 9! = 9 * 8!
#.....
# 2! = 2*1!
# 1! = 1


def fun(n):  # fun求n的阶乘
    # 基线条件(n = 1 不能再往下分了,所以叫基线条件)
    if n == 1:
        return 1

    # 递归条件(只要n不等于1,就可以继续往下分)
    return n * fun(n-1)


res = fun(10)  # res = 10*fun(9)/10*9*fun(8)/
print(res)

作业

1.用函数实现一个判断用户输入的年份是否是闰年的程序
能被400整除的年份
能被4整除,但是不能被100整除的年份
以上2种方法满足一种即为闰年

while True:
    user_input = int(input('请输入年份:'))

    if user_input % 400 == 0 or user_input % 4 == 0 and user_input % 100 != 0:
        print('{}是闰年'.format(user_input))
    else:
        print('{}不是闰年'.format(user_input))
  1. 猴子吃桃问题(递归):
    猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个。第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了,求第一天共摘了多少桃子?
在这里插入代码片
上一篇:Lesson-10 函数(下)


下一篇:Linux环境搭建