Python基础 变量的作用域(python变量的定义位置) 函数(递归函数)斐波那契数列

简介: python变量定义的位置会让变量有不同的作用域,其中包括全局可使用的全局变量,和函数内定义的,只能函数内使用的局部变量。可以用特殊方法使局部变量变成全局变量。

​python变量定义的位置会让变量有不同的作用域,其中包括全局可使用的全局变量,和函数内定义的,只能函数内使用的局部变量。可以用特殊方法使局部变量变成全局变量。

变量的作用域
1、程序代码能访问该变量的区域
2、根据变量的有效范围可分为:

局部变量:
在函数内定义并使用的变量,只在函数内部有效,局部变量使用global声明,这个变量就会成为全局变量
全局变量:
函数体外定义的变量,可作用于函数内外

局部变量

def hua(a,b):

c=a+b   #这里的变量c就是局部变量,因为c在是函数体内进行定义的变量,a,b为函数的形参,作用范围也是函数的内部,相当于局部变量
print(c)

print(c) #报错因为a,b超出了起作用的范围(超出了作用域)

print(a) #报错

全局变量

name="华老师" #在函数外定义的变量,name的作用范围为函数内部和外部都可以使用---称为全局变量
print(name)
def hua2():

print(name)

调用函数

hua2()

局部变量使用global声明可以成为全局变量

def hua3():

global age      #函数内部定义的变量,局部变量,局部变量使用global声明,这个变量实际上就变成的全局变量
age=20      #用global声明该变量,该变量定义时就会变成1全局函数
print(age)

hua3()
print(age)



递归函数

什么是递归函数:
如果在一个函数的函数体内调用量该函数本身,这个函数就称为递归函数

递归的组成部分:
递归调用与递归终止条件 #递归函数既然又终止和调用条件,那么函数里面的语法肯定又if和else
if 终止条件 else 否则就执行递归函数

递归的调用过程:
每递归调用一次函数,都会在栈内存分配一个栈帧
每执行完一次函数,都会释放相应的空间

递归的优缺点:
缺点:
占用内存多,效率低下
优点:
思路和代码简单

def hua(n):

if n==1:   #递归函数的终止条件
    return 1
else:  #递归函数的调用条件(什么时候终止,否则就调用)
    return n*hua(n-1)

print(hua(6)) #返回值是720.

"""
运行实例:

hua(6) # 720

6fac(5) # 6(120)

6(5hua(4)) # 6(524))

6(5(4hua(3))) # 6(5(46))

6(5(4(3hua(2)))) # 6(5(4(32)))

6(5(4(3(2hua(1)))) # 6(5(4(3(21))))
"""

斐波那契数列

def fib(n):

if n==1:  #终止条件
    return 1
elif n==2:
    return 1
else: #调用条件(什么时候终止,否则就调用)
    return fib(n-1)+fib(n-2)

斐波那契数列第六位上的数字

print(fib(6)) #8

输出这个列表的前6位上的数字

for i in range(1,7):

print(fib(i))

相关文章
|
2天前
|
测试技术 开发者 Python
Python中的装饰器:提升函数的灵活性和可重用性
在Python编程中,装饰器是一种强大的工具,它可以在不修改函数本身的情况下,动态地扩展函数的功能。本文将介绍装饰器的工作原理及其在实际开发中的应用,帮助读者更好地理解和利用这一特性。
|
1天前
|
存储 Python
在Python中,匿名函数(lambda表达式)是一种简洁的创建小型、一次性使用的函数的方式。
【6月更文挑战第24天】Python的匿名函数,即lambda表达式,用于创建一次性的小型函数,常作为高阶函数如`map()`, `filter()`, `reduce()`的参数。lambda表达式以`lambda`开头,后跟参数列表,冒号分隔参数和单行表达式体。例如,`lambda x, y: x + y`定义了一个求和函数。在调用时,它们与普通函数相同。例如,`map(lambda x: x ** 2, [1, 2, 3, 4, 5])`会返回一个列表,其中包含原列表元素的平方。
13 4
|
2天前
|
JSON 数据格式 索引
Python内置函数如`print()`输出信息,`len()`计算长度
【6月更文挑战第23天】Python内置函数如`print()`输出信息,`len()`计算长度,`type()`识别类型,`range()`生成序列,`sum()`求和,`min()`和`max()`找极值,`abs()`取绝对值,`round()`四舍五入,`sorted()`排序,`zip()`和`enumerate()`组合及遍历,`map()`和`filter()`应用函数。标准库如`os`用于操作系统交互,`sys`处理解释器信息,`math`提供数学运算,`re`支持正则表达式,`json`处理JSON数据。学习这些能提升编程效率。
11 5
|
1天前
|
Python
在Python中,高阶函数是指那些可以接受一个或多个函数作为参数,并返回一个新的函数的函数。
【6月更文挑战第24天】Python的高阶函数简化代码,增强可读性。示例:`map()`检查用户名合法性,如`["Alice", "Bob123", "Charlie!", "David7890"]`;`reduce()`与`lambda`结合计算阶乘,如1到10的阶乘为3628800;`filter()`找出1到100中能被3整除的数,如[3, 6, 9, ..., 99]。
8 3
|
2天前
|
分布式计算 大数据 调度
MaxCompute产品使用问题之为什么用python写的udf函数跑起来比本地还要慢
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
2天前
|
SQL 分布式计算 大数据
MaxCompute产品使用问题之建了一个python 的 UDF脚本,生成函数引用总是说类不存在,是什么导致的
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
4天前
|
Python
Python解包到变量
【6月更文挑战第15天】
8 3
|
15小时前
|
程序员 Python
Python 中 _ 开头的变量有哪些?
**Python中的单下划线`_`常用于表示私有或内部使用,遵循命名约定而非语言强制规则。它可以避免与关键词冲突,表示临时变量,尤其是在循环中。在解释器中,`_`保存上一次计算的结果。虽然不是真正的私有,但用`_`开头的成员暗示不应直接访问。遵循这些约定能提升代码可读性。**
|
1天前
|
Python
使用Python计算有效值函数(RMS值)
使用Python计算有效值函数(RMS值)
5 0