函数也是一个对象
函数用来保存一些可执行的代码,并且可以在需要时,对这些语句进行多次调用
语法
def 函数名(形参1,形参2,形参3....):
代码块
注意:
函数名也是标识符,必须符合标识符的规范(可以包含字母、数字、下划线但是不能以数字开头)
函数名表示函数对象存储地址 ,使用函数名(形参)
调用函数
一、函数中使用:
形参出现在函数定义中,在整个函数体内都可以使用, 离开该函数则不能使用。
实参出现在主调函数中,进入被调函数后,实参变量也不能使用。
二、调用
形参变量只有在被调用时才分配内存单元,在调用结束时,即刻释放所分配的内存单元。因此,形参只在函数内部有效。函数调用结束返回主调用函数后则不能再使用该形参变量。
实参可以是常量、变量、表达式、函数等,无论实参是何种类型的量,在进行函数调用时,它们都必须有确定的值,以便把这些值传送给形参。因此应预先用赋值,输入等办法使参数获得确定值。
三、不是指针类型在内存中位置不同:
当形参和实参不是指针类型时,在该函数运行时,形参和实参是不同的变量,他们在内存中位于不同的位置,形参将实参的内容复制一份,在该函数运行结束的时候形参被释放,而实参内容不会改变。
举例:
比如你定义一个函数void add(int a, int b),这里的a和b就是形参。
当你进行函数调用的时候,add(1, 2),这里的1和2就是实参。
扩展资料
形参的作用是实现主调函数与被调函数之间的联系,通常将函数所处理的数据,影响函数功能的因素或者函数处理的结果作为形参。
没有形参的函数在形参表的位置应该写void.main 函数也可以有形参和返回值,其形参也称为命令行参数,由操作系统在启动程序时初始化,其返回值传递给操作系统。
两者关系:
在一般传值调用的机制中只能把实参传送给形参,而不能把形参的值反向地传送给实参。因此在函数调用过程中,形参值发生改变,而实参中的值不会变化。而在引用调用的机制当中是将实参引用的地址传递给了形参,所以任何发生在形参上的改变实际上也发生在实参变量上。
总结
def t(a=1,b=2,c=3):
print("a+b+c=", a+b+c)
t()
t(4, 5)
a+b+c= 6
a+b+c= 12
*
,这样这个形参可以获取到所有的实参,它会将所有的实参保存到一个元组中def sum(*a):
result = 0
for i in a:
result += i
print(result)
sum(1, 2, 3, 4, 5, 6, 7, 8, 9)
45
def t(a,b,*c, **d):
print(a)
print(b)
print(c)
print(d)
t(1, 2, 3, 4, 5, d=6, f = 7)
1
2
(3, 4, 5)
{'d': 6, 'f': 7}
基线条件
问题可以被分解为最小问题,当满足基线条件时,递归就不执行了递归条件
可以将问题继续分解的条件现在有ABC三根柱子。要求:将A柱所有的圆盘放到C柱。在移动的过程中可以借助B柱。并且规定大圆盘不能放小圆盘上面,每次只能移动一个盘子。用递归的方式来解决汉诺塔问题
# num表示起始A柱上的圆盘的个数,a,b,c分别表示'A','B','C'三个柱子
def hannuoTower(num, a, b, c):
if num == 1:
# 当num等于1时
# 直接将a上的圆盘移动到c上
print("第 1 个盘子从", a, "->", c)
else:
# 当num大于1时
# 可将一堆圆盘看做两个盘子(最下面的一个圆盘,上面的所有圆盘),这是解题的关键
# 由此可将问题简单的视为三个步骤:
# 1.a借助c将上面的所有圆盘移动到b上
hannuoTower(num-1, a, c, b)
# 2.将a最下面的圆盘移到c上
print("第", num, "个盘子从", a, "->", c)
# 3.b借助a将上面所有的圆盘移动到c上
hannuoTower(num-1, b, a, c)
hannuoTower(3, 'A', 'B', 'C')
第 1 个盘子从 A -> C
第 2 个盘子从 A -> B
第 1 个盘子从 C -> B
第 3 个盘子从 A -> C
第 1 个盘子从 B -> A
第 2 个盘子从 B -> C
第 1 个盘子从 A -> C