博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python 递归
阅读量:4931 次
发布时间:2019-06-11

本文共 887 字,大约阅读时间需要 2 分钟。

一、解释

递归:在调用一个函数的过程中,直接或间接地调用了函数本身这个就叫递归

:Python在递归中没有像别的语言对递归进行优化,所以他的每一次调用都会基于上一次的调用进行,并且他设置了最大的递归数量防止递归外溢

二、实例

#直接调用自己:def func():    print('from func')    func()func()
#间接调用自己def foo():    print('from foo')    bar()def bar():    print('from bar')    foo()foo()
#递归的实现:def age(n):    if n == 1:        return 18    return age(n-1)+2print(age(5))# age(5)=age(4)+2 第一次进入# age(4)=age(3)+2 第二次进入# age(3)=age(2)+2 第三次进入# age(2)=age(1)+2 第四次进入# age(1)=18 第五次进入,最后判断终止条件# age(n)=age(n-1)+2 #n>1  递归终止条件# age(1)=18 #n=1          等于终止条件

三、递归的回溯与递推

递推:像上边递归实现所拆解,递归每一次都是基于上一次进行下一次的执行,这叫递推

回溯:则是在遇到终止条件,则从最后往回返一级一级的把值返回来,这叫回溯

# 实例l =[1, 2, [3, [4, 5, 6, [7, 8, [9, 10, [11, 12, 13, [14, 15,[16,[17,]],19]]]]]]]def search(l):    for item in l:        if type(item) is list:            search(item)        else:            print(item)search(l)

 

转载于:https://www.cnblogs.com/liuxiaowei/p/7262428.html

你可能感兴趣的文章
python netwokx环境搭建
查看>>
面向空实现类继承
查看>>
1303: Decimal
查看>>
奥数 --- 找规律 + 总结
查看>>
Android sendToTarget
查看>>
输出的巧妙思想(解题技巧)
查看>>
[学习] nofollow
查看>>
测试阶段的工作进度
查看>>
《将博客搬至CSDN》
查看>>
ExtJS 刷新后,默认选中刷新前最后一次选中的节点
查看>>
实现一个简单的shell(2)
查看>>
Window 常用命令
查看>>
SMTP协议学习笔记
查看>>
ubuntu18.04下安装eclipse jee
查看>>
在ASP.NET MVC中使用Web API和EntityFramework构建应用程序
查看>>
iOS OpenGL ES简单绘制三角形
查看>>
.NET Core 中正确使用 HttpClient 的姿势
查看>>
求子数组最大值
查看>>
谈谈tmpdir与innodb_tmpdir的区别和用处
查看>>
4.4---建立二叉树的链表
查看>>