zoukankan      html  css  js  c++  java
  • python递归的使用

    一、什么是函数递归?

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

    1.1直接调用

    直接调用指的是:直接在函数内部调用函数自身。

    import sys
    print(sys.getrecursionlimit()) #打印最大递归层数:3000
    
    import sys
    sys.setrecursionlimit(10000)
    def f(n):
        print('from f',n)
    f(0)
    
    1.2间接调用

    间接调用指的是:不在原函数体内调用函数自身,而是通过其他的方法间接调用函数自身。

    def func1():
        print('func1')
        func2()
    def func2():
        print('func2')
    func1()
    
    递归必须要有两个明确的阶段:
    1.递归:一层一层递归调用下去,进入下一层递归的问题规模都将会减小
    

    ​ 2.回溯:递归必须要有一个明确的结束条件,在满足该条件开始一层一层回溯。

    递归的精髓在于通过不断地重复逼近一个最终的结果。

    二、为什么要用递归

    递归的本质就是干重复的活,但是仅仅是普通的重复,我们使用while循环就可以了。

    比如:计算1+...+5的和

    def sum1(i):
        if i == 5:
            return i
        res = sum1(i+1)+i
        print(res)
        return res
    print(sum1(1))
    

    三、如何用递归?

    有一个从小到大排列的整型数字列表,我们判断某一个数字是不是在这个列表里面。

    动图二分法查找数字7:

    lt = [11,33,55,44,77,1,2,86,100]
    #      0  1  2  3  4 5 6  7   8
    def findnum(f_num,nums):
        if not nums:
            print('没找到')
            return
        lens = len(nums)//2
        if f_num > nums[lens]:
            nums = nums[lens+1:]
            findnum(f_num,nums)
        elif f_num < nums[lens]:
            nums = nums[:lens]
            findnum(f_num, nums)
        else:
            print(f'找到了')
    lt.sort()
    findnum(7,lt)
    
  • 相关阅读:
    Linq 入门 顺带 Func与Action
    关于asp.net 的一些好资料地址 , 防止丢失!
    Sql日期时间格式转换 备用
    自己动手写 ASP.NET MVC 分页 part1
    怎么做好一个美食排行榜的用户投票功能?
    「要买车网」免费获取汽车电商要买车网购车优惠券
    MVC Ajax Form & Ajax Valida(笔记)
    C# 序列化高级用法
    我与葡萄城的故事
    生成分布式随机ID
  • 原文地址:https://www.cnblogs.com/cheng825/p/11352402.html
Copyright © 2011-2022 走看看