python中递归函数怎样使用?要注意什么?
Admin 2021-08-20 群英技术资讯 488 次浏览
python中递归函数怎样使用?很多新手在使用递归函数时,会出现多种问题,对此,这篇文章就给大家分享一下python中递归函数的用法以及要注意的一些问题,有需要的朋友可以参考。
递归函数一定要编写终止条件,否则将产生无限递归。(死循环)
""" 使用代码循环输出故事:从前有座山,山里有座庙... """ # ------------while循环 (暂时忽略死循环)--------------- while True: print("从前有座山,山里有座庙...") # ---------------通过定义一个方法, 在while循环里面调用实现( 暂时忽略死循环)--------------- def func_story(): print("从前有座山,山里有座庙...") while True: func_story() # ---------------使用递归的方法实现循环--------------- def story(): print("从前有座山,山里有座庙...") story() story() # 报错:RecursionError: maximum recursion depth exceeded while calling a Python object
这里就引申到一个递归的最大深度。
import sys # 获取最大递归深度 res = sys.getrecursionlimit() print(res) # 输出:1000 # 递归最大深度: def func(n): print(n) n += 1 func(n) func(1) # python 3 打印到998就停止打印了
我们可以设置递归的最大深度。但是能够达到的最大深度,跟电脑配置也有关系:
import sys # 设置递归的深度 sys.setrecursionlimit(10000) # 递归最大深度: def func(n): print(n) n += 1 func(n) func(1) # python 3 打印到3221就停止打印了
通过缓存解决最大递归限制的问题:
递归函数示例一:
# 18 20 22 24 def age(n): if n == 1: return 18 else: return age(n-1) + 2 print(age(1)) # 输出:18 print(age(2)) # 输出:20 print(age(3)) # 输出:22 print(age(4)) # 输出:24
递归函数示例二:打印三级菜单
# 我们有一个这样的三级菜单 menu = { "功能测试": { "用例管理": { "添加用例": {}, "删除用例": {}, "复制用例": {} }, "元素管理": { "添加元素": {}, "删除元素": {}, "复制元素": {} }, }, "接口测试": { "API管理": { "添加api": {}, "删除api": {}, "复制api": {} }, "环境管理": { "添加环境": {}, "删除环境": {}, "复制环境": {} }, }, } def query_menu(menu:dict): """ 一级级查询菜单信息 :return: """ # 用户输入q退出 while True: for k in menu:print(f"当前菜单:{k}") key = input(">>>").strip() if key == "q": return key elif key in menu.keys() and menu[key]: res = query_menu(menu[key]) if res == "q": return "q" query_menu(menu)
输出结果:
关于python递归函数就介绍到这,上述实例具有一定的参考价值,感兴趣的朋友可以参考学习,希望能对大家有帮助,想要了解更多python递归函数的内容,大家可以关注其他文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文为大家整理了九个Python列表生成式的面试题(从简单到困难排序),可以帮助大家提高列表生成式的理解水平,感兴趣的小伙伴可以学习一下
这篇文章主要为大家介绍了python根据照片获取地理位置及泄露防御,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
python的转义字符是\,可以转义很多字符,比如\n表示换行,\t表示制表符,字符\本身也要转义,所以\\表示的字符就是\。Python还允许用“r”表示内部的字符串默认不转义。
这篇文章主要为大家详细介绍了Python实现FIFO(先进先出)缓存置换算法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
一个简单的贪吃蛇程序,供大家参考,具体内容如下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008