函数递归调用

在函数内部,可以调用其它函数,如果一个函数在内部调用自身,即是递归调用

为防止无限递归类似于死循环,需要如下:
  1、必须要有一个明确的返回值;
  2、每次进入更深一层递归时,问题规模应该比上次递归都有所减少;
  3、递归效率不高,当层次过多会导致栈溢出

例如:

def calc(n):
print(n)
if int(n/2) == 0:
return n res=calc(int(n/2))
return res v=calc(10)
print(v)
返回结果:
10
5
2
1
1

程序执行过程:

  

  调用calc()函数,传入参数10;calc()函数第一次执行;
  进入calc函数,打印10
  判断不满足
  再次调用calc函数传入参数5,calc()函数第二次执行;
  此时第一次calc函数在等待第二次calc函数的返回结果赋值给res

第二次calc函数执行:

  打印5
  判断不满足
  执行第三次calc函数,传入参数2,calc()函数第三次执行;
  此时第二次calc函数在等待第三次calc函数的返回结果赋值给res

第三次calc函数执行:

  打印2
  判断不满足
  执行第四次calc函数,传参数1,calc()函数第四次执行;
  此时第三次calc函数在等待第四次calc函数的返回结果赋值给res

第四次calc函数执行:

  打印1
  判断成立,执行return 1
  第四次calc函数执行完毕,把1返回给第三次calc函数

  第三次calc函数在等待第四次函数的返回结果;

  第四次calc函数返回了1

  第三次calc函数拿到结果后赋值给res;

  第三次calc函数执行return 1返回给第发给次函数
************************
  第二次calc函数在等待第三次函数的返回结果;

  第三次calc函数返回了1

  第二次calc函数把1赋值给res

  第二次calc函数执行return 1返回给第一次函数
************************
  第一次calc函数在等待第二次函数的返回结果;

  第二次calc函数返回了1

  第一次calc函数把1赋值给rest

  第一次calc函数执行return 1返回给调用它的程序
************************

  
程序接收到了结果1赋值给变量v
最后打印变量

#递归实例:问路

问路最终分为2种情况:
  - 问到最后没人知道;

  - 问到某个人时知道;

  - 现在假设有个人物列表代表问路时需要问的人

  - 假设问到最后Tom知道路

person_list=["zhangsan","lisi","Tom"] #路人列表,需要被问到的人
def find_way():
if len(person_list) == 0:
return "No one know the way" #问到最后没人知道 person=person_list.pop(0) #依次弹出1个人去问 if person == "Tom": #只有Tom才知道,弹出的人不是Tom,表示不知道,需要问下一个人
return "%s said:I know the way,over there" %person
res=find_way()
return res v=find_way()
print(v)
返回结果:
Tom said:I know the way,over there

python之函数递归的更多相关文章

  1. python基础-函数递归

    函数递归 概念:直接或间接地重复调用函数本身,是一种函数嵌套调用的表现形式. 直接调用:在函数内部,直接调用函数本身 def foo(): print("这是foo函数") foo ...

  2. (十七)python 3 函数递归

    递归函数 即自己调用自己,递归中可以函数自身调用自身,但是使用时类似于条件循环一样,要有递归的终止条件 优点:使用递归时,常常可以让代码更加简洁 缺点:递归会占用比较多的内存,当递归次数比较多时,性能 ...

  3. python 关于函数递归调用自己

    爬取b站博人传 每页短评20个,页数超过1000页, 代码如下 import requests import json import csv def main(start_url): headers ...

  4. python全栈开发-Day12 三元表达式、函数递归、匿名函数、内置函数

    一. 三元表达式 一 .三元表达式 仅应用于: 1.条件成立返回,一个值 2.条件不成立返回 ,一个值 def max2(x,y): #普通函数定义 if x > y: return x els ...

  5. Python第七天 函数 函数参数 函数里的变量 函数返回值 多类型传值 函数递归调用 匿名函数 内置函数

    Python第七天   函数  函数参数   函数里的变量   函数返回值  多类型传值     函数递归调用   匿名函数   内置函数 目录 Pycharm使用技巧(转载) Python第一天   ...

  6. python之旅:三元表达式、列表推导式、生成器表达式、函数递归、匿名函数、内置函数

    三元表达式 #以下是比较大小,并返回值 def max2(x,y): if x > y: return x else: return y res=max2(10,11) print(res) # ...

  7. Python之路Python全局变量与局部变量、函数多层嵌套、函数递归

    Python之路Python全局变量与局部变量.函数多层嵌套.函数递归 一.局部变量与全局变量 1.在子程序中定义的变量称为局部变量,在程序的一开始定义的变量称为全局变量.全局变量作用域是整个程序,局 ...

  8. python 之 函数 面向过程 三元表达式 函数递归

    5.11 面向过程编程思想 核心是'过程'二字,过程即解决问题的步骤,即先干什么,再干什么........ 基于面向过程编写程序就好比在设计一条流水线,是一种机械式的思维方式. 总结优缺点: 优点:复 ...

  9. python day-15 匿名函数 sorted ()函数 filter()函数 map()函数 递归 二分法

    一.匿名函数 匿名函数的结构:变量   =  lamda  参数: 返回值 a  =  lamda  x : x*x       # x为参数,   : 后边的为函数体 print(a(x)) def ...

随机推荐

  1. spring boot项目中处理Schedule定时任务

    项目中,因为使用了第三方支付(支付宝和微信支付),支付完毕后,第三方支付平台一般会采用异步回调通知的方式,通知商户支付结果,然后商户根据通知内容,变更商户项目支付订单的状态.一般来说,为了防止商户项目 ...

  2. 多线程、互斥锁、异步、GIL

    多线程-threading python的thread模块是比较底层的模块,python的threading模块是对thread做了一些包装的,可以更加方便被使用 from threading imp ...

  3. IDEA汉化

    1.- 汉化包 提取码: 4mbq 2.打开IDEA,执行下列操作:在主界面选择File → Settings → Appearance&Behavior → Appearance → 勾选O ...

  4. 如何在宿主机上执行容器里的jmap,jtack,jstat 命令获取信息(原创)

    一般情况下,我们要获取docker容器里的jvm信息只能进入容器后执行jmap,jstack,jstat 命令去获取,jstack,jstat还好,但是jmap dump的文件要拿出来,得先copy ...

  5. mybatis的缓存简说

    一级缓存(不需配置,默认为一级缓存): 1)相当于 sqlsession 级别的缓存 2)当 session 关闭(close)或者提交(commit)后,缓存数据清空 3)当发生insert.upd ...

  6. [UE4]瞬移对象

    一.首先把Predict Projectile Path By TraceChannel的Draw Debug Type改成none,不显示射线,改成该选项并不会影响正常使用. 二.避免瞬移穿透底板 ...

  7. Spark下的FP-Growth和Apriori

    基本概念 关联分析是一种在大规模数据集中寻找有趣关系的非监督学习算法.这些关系可以有两种形式:频繁项集或者关联规则.频繁项集(frequent item sets)是经常出现在一块的物品的集合,关联规 ...

  8. 正式表达式判断私有 IP 地址

    正式表达式判断私有 IP 地址   ^1(((0|27)(.(([1-9]?|1[0-9])[0-9]|2([0-4][0-9]|5[0-5])))|(72.(1[6-9]|2[0-9]|3[01]) ...

  9. 【学习】数据聚合和分组运算【groupby】

    分组键可以有多种方式,且类型不必相同 列表或数组, 某长度与待分组的轴一样 表示DataFrame某个列名的值 字典或Series,给出待分组轴上的值与分组名之间的对应关系 函数用于处理轴索引或索引中 ...

  10. Open CDN 2.0管控端和节点端安装

    原文:http://www.safecdn.cn/cdn/2018/12/opencdn-2-0/1076.html OpenCDN是一套快速部署CDN加速的工具,针对专门提供CDN加速服务的企业或对 ...