def<函数名>(<参数(0个或者多个)>):
<函数体>
return <返回值>
#计算n!
def fact(n):
s=1
for i in range(1,n+1):
s*=i
return s
n = input()
b=fact(int(n))
print(b)
3628800
函数的使用及调用过程
函数的参数传递
- 可选参数一定要在必选参数后面
#可选参数:计算n!//m
def fact(n,m=1): #m是可选参数
s=1
for i in range(1,n+1):
s*=i
return s//m
b=fact(10,5) #位置传递
c=fact(m=5,n=10) #名称传递
print(b,c)
725760 725760
#可变参数:计算n!//m
def fact(n,*b): #*b为可变参数
s=1
for i in range(1,n+1):
s*=i
for item in b:
s*=item
return s
print(fact(3))
print(fact(3,4,6))
print(fact(3,10,9,10))
6
144
5400
#可选参数:计算n!//m
def fact(n,m=1): #m是可选参数
s=1
for i in range(1,n+1):
s*=i
return s,m,s//m #返回三个值
b=fact(10,5) #位置传递
c=fact(m=5,n=10) #名称传递
x,y,z = fact(10,5) #返回的三个值分别赋给xyz
print(b,c)
print(x,y,z)
(3628800, 5, 725760) (3628800, 5, 725760)
3628800 5 725760
global
保留字在函数内部使用全局变量n,s=10,100 #此处n,s是全局变量
def fact(n): #fact函数中的n,s是局部变量
s=1
for i in range(1,n+1):
s*=i
return s
print(fact(n),s) #n,s是全局变量
3628800 100
n,s=10,100 #此处n,s是全局变量
def fact(n): #fact函数中的n,s是局部变量
global s #声明是全局变量
for i in range(1,n+1):
s*=i
return s
print(fact(n),s) #n,s是全局变量
362880000 362880000
ls=['F','f'] #创建全局变量s
def func(a):
ls.append(a) #此处ls是列表类型,未真实创建则等同于全局变量
return
func('C') #全局变量ls被修改
print(ls)
['F', 'f', 'C']
ls=['F','f'] #创建全局变量s
def func(a):
ls = [] #此处ls是列表类型,真实创建ls是局部变量,函数运行完成就被释放
ls.append(a)
return
func('C') #局部变量ls被修改
print(ls)
['F', 'f']
<函数名>=lambda<参数>:<表达式>
#
f = lambda x,y:x+y
print(f(10,15))
25
#SevenDigitsDrawV1.py
import turtle as t
def drawLine(draw): #绘制单段数码管
t.pendown() if draw else t.penup()
t.fd(40)
t.right(90)
def drawDigit(digit): #根据数字绘制七段数码管
drawLine(True) if digit in [2,3,4,5,6,8,9] else drawLine(False)
drawLine(True) if digit in [0,1,3,4,5,6,7,8,9] else drawLine(False)
drawLine(True) if digit in [0,2,3,5,6,8,9] else drawLine(False)
drawLine(True) if digit in [0,2,6,8] else drawLine(False)
t.left(90)
drawLine(True) if digit in [0,4,5,6,8,9] else drawLine(False)
drawLine(True) if digit in [0,2,3,5,6,7,8,9] else drawLine(False)
drawLine(True) if digit in [0,1,2,3,4,7,8,9] else drawLine(False)
t.left(180) #为后续数字确定位置
t.penup() #为后续数字确定位置
t.fd(20) #为后续数字确定位置
def drawDate(date):
for i in date:
drawDigit(eval(i)) #通过eval()函数将数字变为整数
def main():
t.setup(800,350,200,200)
t.penup()
t.fd(-300)
t.pensize(5)
drawDate('20200317')
t.hideturtle()
t.done
main()
#SevenDigitsDrawV2.py
import turtle as t
import time as ti
def drawGap(): #绘制数码管间隔
t.penup()
t.fd(5)
def drawLine(draw):
drawGap() #绘制单段数码管
t.pendown() if draw else t.penup()
t.fd(40)
drawGap()
t.right(90)
def drawDigit(digit): #根据数字绘制七段数码管
drawLine(True) if digit in [2,3,4,5,6,8,9] else drawLine(False)
drawLine(True) if digit in [0,1,3,4,5,6,7,8,9] else drawLine(False)
drawLine(True) if digit in [0,2,3,5,6,8,9] else drawLine(False)
drawLine(True) if digit in [0,2,6,8] else drawLine(False)
t.left(90)
drawLine(True) if digit in [0,4,5,6,8,9] else drawLine(False)
drawLine(True) if digit in [0,2,3,5,6,7,8,9] else drawLine(False)
drawLine(True) if digit in [0,1,2,3,4,7,8,9] else drawLine(False)
t.left(180) #为后续数字确定位置
t.penup() #为后续数字确定位置
t.fd(20) #为后续数字确定位置
#遇到-是年,遇到=是月,遇到+是日
def drawDate(date):
t.pencolor('red') #date为日期,格式为‰Y-‰m=%d+
for i in date:
if i == '-':
t.write('年',font = ('Arial',18,'normal'))
t.pencolor('green')
t.fd(40)
elif i == '=':
t.write('月',font = ('Arial',18,'normal'))
t.pencolor('blue')
elif i == '+':
t.write('日',font = ('Arial',18,'normal'))
else:
drawDigit(eval(i))
def main():
t.setup(800,350,200,200)
t.penup()
t.fd(-300)
t.pensize(5)
drawDate(ti.strftime('%Y-%m=%d+',ti.gmtime()))
t.hideturtle()
t.done
main()
把代码当作资源进行抽象:
函数和对象是代码复用的两种主要形式
模块化设计:分而治之
紧耦合:两个部分之间交流很多,无法独立存在
松耦合:两个部分之间交流很少,可以独立存在,由清晰独立的接口
在模块内部尽可能紧耦合、模块之间尽可能松耦合
函数递归:函数中调用函数自身的方式,类似数学归纳法
#n!计算
def fact(n):
if n==0:
return 1
else:
return n*fact(n-1)
n=10
print(fact(n))
3628800
#字符串反转-递归
# s=input()
# s[::-1]
def rvs(s):
if s == '':
return s
else:
return rvs(s[1:])+s[0]
s = 'sdf'
rvs(s)
'fds'
#斐波那契数列
def f(n):
if n ==1 or n == 2:
return 1
else:
return f(n-1)+f(n-2)
n=10
f(n)
55
#汉诺塔
from time import perf_counter
st = perf_counter()
count = 0
def hanoi(n,src,dst,mid):
#n是圆盘数,src是源柱子,dst是目标柱子,mid是中间柱子
global count
if n == 1:
print('{}:{}->{}'.format(1,src,dst))
count +=1
else:
hanoi(n-1,src,mid,dst)
print('{}:{}->{}'.format(n,src,dst))
count+=1
hanoi(n-1,mid,dst,src)
n = 3
hanoi(n,'a','c','b')
print(count,perf_counter()-st)
1:a->c
2:a->b
1:c->b
3:a->c
1:b->a
2:b->c
1:a->c
7 0.00025690000256872736
#KochDrawV1
import turtle as t
def koch(size,n):
if n == 0:
t.fd(size)
else:
for angle in [0,60,-120,60]:
t.left(angle)
koch(size/3,n-1)
def main():
t.setup(800,400)
t.penup()
t.goto(-300,-50)
t.pendown()
t.pensize(2)
koch(600,3)
t.hideturtle()
t.done
main()
#KochDrawV2
import turtle as t
def koch(size,n):
if n == 0:
t.fd(size)
else:
for angle in [0,60,-120,60]:
t.left(angle)
koch(size/3,n-1)
def main():
t.setup(600,600)
t.penup()
t.goto(-200,100)
t.pendown()
t.pensize(2)
level=int(input())
koch(400,level)
t.right(120)
koch(400,level)
t.right(120)
koch(400,level)
t.hideturtle()
t.done
main()
描述
补充编程模板中代码,完成如下功能:
以整数17为随机数种子,获取用户输入整数N为长度,产生3个长度为N位的密码,密码的每位是一个数字。每个密码单独一行输出。
产生密码采用random.randint()函数。
import random
def genpwd(length):
return random.randint(pow(10,length-1),pow(10,length))
length = eval(input())
random.seed(17)
for i in range(3):
print(genpwd(length))
634
524
926
描述
补充编程模板中代码,完成如下功能:
获得用户输入数字N,计算并输出从N开始的5个质数,单行输出,质数间用逗号,分割。
注意:需要考虑用户输入的数字N可能是浮点数,应对输入取整数;最后一个输出后不用逗号。
def prime(m):
count = 1
while(count<=5):
isprime = 1
for i in range(2,m):
if m%i == 0:
isprime = 0
if isprime == 1:
if count == 5:
print(m,end='')
else:
print(m,end=',')
count+=1
m+=1
n = eval(input())
prime(int(n))
13,17,19,23,29
#参考代码
def prime(m):
for i in range(2,m):
if m % i == 0:
return False
return True
n = eval(input())
n_ = int(n)
n_ = n_+1 if n_ < n else n_
count = 5
while count > 0:
if prime(n_):
if count > 1:
print(n_, end=",")
else:
print(n_, end="")
count -= 1
n_ += 1
13,17,19,23,29