函数基础与递归

函数是一系列常被重复使用的语句被抽取成一个"集合体",每次调用这个函数就相当于调用了这些语句,这样总体的代码函数会大幅降低。

例1:打印列表各元素值

a = list("python")
i = 0
while i < len(a):
print a[i]
i = i + 1
b = [1, 3, 4, 6]
i = 0
while i < len(b):
print b[i]
i = i + 1
c = range(1, 11)
i = 0
while i < len(c):
print c[i]
i = i + 1

从上边的例子可以看出,程序主要有3个列表a、b、c并打印了这三个列表里的数据,但代码行数较多,也不利于对程序的理解,其实可以将
i = 0
while i < len():
print
i = i + 1

抽象成函数printList,实际使用printList函数时是针对每个不同的列表来使用的,每次都打印不同的列表,那么每次打印的内容,可以作为printList函数的参数,传给printList函数,传入的不同内容即实现打印不同的内容,因此函数既有要做的事情即函数体(语句块),还要有处理对象(参数)。

1 定义函数

自定义定义函数的语法格式:
def 函数名(参数列表):
语句块

需要注意作为函数的语句,前需要按Tab键进行缩进对齐,没有按Tab缩进对齐的语句不属于该函数。

例2:printList函数的实现

def printList(x):
i = 0
while i < len(x):
print x[i]
i = i + 1

在定义好了函数之后,原来的"例1"的程序可以改成如下的样子。

#coding:utf-8

定义函数printList、x为参数(形参)

def printList(x):
i = 0
while i < len(x):
print x[i]
i = i + 1
a = list("python")

函数printList的调用,a为实参

printList(a)
b = [1, 3, 4, 6]
printList(b)
c = range(1, 11)
printList(c)

这样的程序及结构是不是清晰一些了呢?

2 全局和局部变量

函数体里的变量是局部的,可以在函数内部使用,而函数体外部的变量是全局的,可以在函数体内部访问(读),但如果想在函数内部修改全局变量得先用global声明一下要修改的全局变量。

x = 12
def m():
global x
x = 13
print x
m()
print x

如果函数里没有对某变量global进行声明就修改全局变量的值,程序会视为函数有和全局变量同名的局部变量,那么同名的全局变量对本函数不可见。

x = 12
def m():
#global x
x = 13
print x
m()
print x

3 递归

递归,函数定义里使用了函数本身。一般会使用if_else结构控制递归的进入和退出。

例3:求n!(n的阶乘)

用递归很容易,求解n!的数学过程如下所示,需要注意的是0!和1!都为1。
s0 = 1
s1 = 1 * s0
s2 = 2 * s1 = 2 * 1
s3 = 3 * s2 = 3 * 2 * 1
....
sn = n * s(n-1) = n * (n - 1) * .... * 2 * 1

可以用while循环来实现。

def Factorial(x):
i = 1
s = 1
while i <= x:
s = i * s
i = i + 1
return s
print Factorial(5)

也可以用递归来实现。

def Factorial(x):
if x == 0: # 终止、退出
return 1
else:
return x * Factorial(x - 1) #递归进入
print Factorial(3)

例4:利用递归实现正序打印列表

s = "python"
def printS(x, index):
if index < len(s):
print x[index],
printS(x, index + 1)

printS(s, 0)

相关推荐
MATLAB代码顾问13 分钟前
Python实现蜂群算法优化TSP问题
开发语言·python·算法
yaodong51826 分钟前
不会Python也能数据分析:Gemini 3.1 Pro解决办公问题的SQL自动生成
python·sql·数据分析
jinanwuhuaguo34 分钟前
(第三十三篇)五月的文明奠基:OpenClaw 2026.5.2版本的文明级解读
android·java·开发语言·人工智能·github·拓扑学·openclaw
BU摆烂会噶38 分钟前
【LangGraph】持久化实现的三大能力——时间旅行
数据库·人工智能·python·postgresql·langchain
有一个好名字2 小时前
工具即双手 —— 从 Bash 到 Tool Dispatch Map
开发语言·chrome·bash
Lyyaoo.2 小时前
优惠券秒杀业务分析
java·开发语言
消失的旧时光-19432 小时前
统一并发模型:线程、Reactor、协程本质是一件事(从线程到协程 · 第6篇·终章)
java·python·算法
DevilSeagull2 小时前
MySQL(2) 客户端工具和建库
开发语言·数据库·后端·mysql·服务
MATLAB代码顾问3 小时前
改进遗传算法(IGA)求解作业车间调度问题(JSSP)——附MATLAB代码
开发语言·matlab
syker3 小时前
AIFerric深度学习框架:自研全栈AI基础设施的技术全景
开发语言·c++