zoukankan      html  css  js  c++  java
  • 函数的递归,面向过程编程

    一、什么是函数递归

    函数的嵌套调用是:函数嵌套函数。函数的递归调用:它是一种特殊的嵌套调用,但是它在调用一个函数的过程中,又直接或间接地调用了它自身

    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端的用户功能层,但是接口层数据处理层是通用的

    既然选择了远方,只能风雨兼程
  • 相关阅读:
    Spring事件机制
    设计模式(07)——设计原则(2)
    设计模式(06)——设计原则(1)
    使用Feign发送HTTP请求
    设计模式(05)——组合和继承
    设计模式(04):接口和抽象类
    设计模式(03):面向对象与面向过程的区别与联系
    设计模式(二):面向对象及其特性分析
    设计模式(一):学习大纲
    Java8日期时间——LocalDateTime的使用以及相互转换
  • 原文地址:https://www.cnblogs.com/lzss/p/11413794.html
Copyright © 2011-2022 走看看