一、什么是函数递归
函数的嵌套调用是:函数嵌套函数。函数的递归调用:它是一种特殊的嵌套调用,但是它在调用一个函数的过程中,又直接或间接地调用了它自身
def foo():
print('hello hello')
foo()
foo() #会进入死循环
如果递归函数不断地调用函数自身,那么这个递归函数将会进入一个死循环,因此我们应该递归函数一个明确的结束条件
1.1直接调用
直接在函数内部调用函数自身
import sys
print(f'最大递归层数:{sys.getrecursionlimit()}')
##最大递归层数:3000
import sys
##修改递归层数
sys.setercursionlimit(10000)
def foo(n):
print('from foo',n)
foo(0)
1.2间接调用
不在原函数体内调用函数自身,而是通过其他的方法间接调用函数自身
def bar():
print('hello hello')
foo()
def foo():
print('hello lzs')
bar()
bar()
递归必须要有两个明确的阶段:
1、递归:一层一层递归下去,进入下一层递归的问题规模将会减小
2、回溯:递归必须有一个明确的结束条件,在满足该条件开始一层一层回溯,递归的精髓在于通过不断地重复逼近一个最终的结果
def age(n):
if n==1:
return 26
res=age(n-1)+2
return res
print(f'age(5):{age(5)}')
##age(5):34
二、为什么要用递归
递归的本质就是干重复的活,但是仅仅是普通的重复,我们使用while循环就可以了
lis=[1,[2,[3,[4,[5,[6]]]]]]
def tell(lis):
for i in lis:
if type(i) is list:
tell(i)
else:
print(i)
tell(lis)
'''
1
2
3
4
5
6
'''
三、如何用递归
用二分法在数组里查找某一个数
def search(serch_num,nums):
mid_index=len(nums)//2
print(nums)
if not nums:
print('没找到')
return
if serch_num>nums[mid_index]:
nums=nums[mid_index+1]
search(search_num,nums)
elif search_num<nums[mid_index]:
nums=nums[:mid_index]
search(search_num,nums)
else:
print('找到了')
search(7,nums)
面向过程编程
面向过程编程,核心就是编程二字,过程指的是解决问题的步骤,即先干什么,后干什么,再干什么,然后干什么
基于该思想编写程序就好比在设计一条一条流水线,面向对称编程其实是一种机械式的思维方式
当我们写登陆功能,我们首先需要输入账号,密码,然后认证两次密码是否相同,然后从数据库中读取密码验证用户密码输入是否正确,然后输入验证码,之后,我们就能够实现登陆功能,这样把登陆功能问题流程化,进而是解决问题的思路非常清晰
优点:复杂的问题流程化,进而简单化
缺点:扩展性差
一、注册功能
##接受用户输入用户名,进行合法性校验,拿到合法的用户名
def check_username():
username=input('username>>>>').strip()
if username.isalpha():
return username
else:
print('用户名必须为字母')
##接受用户输入密码,进行合法性校验,拿到合法的密码
def check_pwd():
while True:
pwd=input('password>>>').strip()
if len(pwd)<5:
print('密码长度至少5位')
continue
re_pwd=input('re_password>>>').strip()
if pwd==re_pwd:
rerurn pwd
else:
print('两次输入密码不一致')
##将合法的用户名和密码写入文件
def insert(username,pwd,path='text.txt')
with open(path,'a',encoding='utf8')as fa:
fa.write(f'{username}:{pwd}
')
2、封装文件读写功能
##数据处理层
def select(username):
with open('text','r',encoding='utf8')as fr:
for line in fr:
info=line.strip('
').split(':')
if username==info[0]
return info
def tell_info():
username=input('username>>>>').strip()
info=select(username)
print(info)
##用户功能层
def register():
while True():
username=input('username>>>>').strip()
##检测用户是否重复,如果重复则重新输入
res=select(username)
if res:
print('用户名已经存在')
else:
break
while True:
pwd=input('password>>>>').strip()
re_pwd=input('re_password').strip()
if pwd!=re_pwd:
print('两次输入密码不一致,请重新输入')
else:
break
##把注册功能分开之后,功能与功能直接解耦合,复杂的问题流程化,更加清晰
3、分层实现功能
用户功能层:实现用户具体的功能
接口层:连接数据处理层和用户功能层
数据处理层:处理数据后把结果交给接口层
分层实现功能的好处:当我们需要实现web端和app端的软件,我们只要把数据处理层和接口层写好,然后实现不同的用户功能层即可,web端使用web端的用户功能层,app端使用app端的用户功能层,但是接口层数据处理层是通用的