Python递归的概念是什么,递归方法有哪些原则要注意
Admin 2022-05-27 群英技术资讯 653 次浏览
python数据类型: python数据结构:数据类型.
python的输入输出: python数据结构之输入输出、控制和异常.
python面向对象: python数据结构之面向对象.
python算法分析: python数据结构算法分析.
python数据结构之栈、队列和双端队列
递归是在进行重复性工作中经常考到的问题,非常值得学习。
递归是解决问题的一种方法,它将问题不断地分成更小的子问题,直到子问题可以用普通的方法解决。通常情况下,递归会使用一个不停调用自己的函数。尽管表面上看起来很普通,但是递归可以帮助我们写出非常优雅的解决方案。对于某些问题,如果不用递归,就很难解决。
上面的话很难理解,我们用一个例子来说明:我们需要求解一个数组的所有数值之和。
#用for循环的简单函数 def getsum(numlist): a=0 for i in numlist: a=i+a return a
结果如下:
如果暂时没有 while
循环和 for 循环。应该如何计算结果呢? 这个时候就需要想到我们计算加法的时候,是接受2个参数的函数,根据这个思想,我们将求一列数之和重新定义成求数字对之和。
注:最内层的括号对(7 + 9)不用 循环或者其他特殊语法结构就能直接求解。
拟代码表示
#first(list)返回列表中的第一个元素,rest(list)则返回其余元素。用 Python 可以轻松地实现这个等式, getsum(list)=first(list)+getsum(rest(list))
代码表示:
#这是一个递归小案例,这个函数在函数内部自己调用了自listsum(numlist[1:]) def listsum(numlist): if len(numlist)==1:#当数组的长度为1时,代表是数组是一个数了 return numlist[0] else: return numlist[0] + listsum(numlist[1:])#第一个数加上后面的数,这里自己调用了自己,是数组不断递归的条件
在这一段代码中,有两个重要的思想值得探讨。首先,第 2 行检查列表是否只包含一个元素。 这个检查非常重要,同时也是该函数的退出语句。对于长度为 1 的列表,其元素之和就是列表中的数。其次,listsum 函数在第 5 行调用了自己!这就是我们将 listsum
称为递归函数的原因——递归函数会调用自己。
演示一下相加过程
递归算法有三个重要的原则:
让我们看看我们第一个案例是怎么实现这个部分的:
len(numlist)==1
用来判断停止条件numlist[1:]
代表问题的数据以某种方式变得更小return numlist[0] + listsum(numlist[1:])
代表递归地调用自己递归的逻辑并不是循环,而是将问题分解成更小、更容易解决的子问题。
下面展示一下将10进制的29转换为2进制数的方法,按照这个方法,可以将10进制转化为任意进制的数。
这里我们用递归来实现2~16进制数的转换
#n代表要转化的10进制数,base代表你要实现的多少进制的数 def toStr(n, base): convertString = "0123456789ABCDEF"#取对应位置的字符 if n < base:#如果10进制数小于你所转换的进制数位数,则直接选择字符 return convertString[n] else:#递归核心,n//base获取结果,然后进行递归 return toStr(n//base, base) + convertString[n%base]
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家介绍了python人工智能tensorflow函数np.random模块使用方法,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
大家好,本篇文章主要讲的是Python循环语句介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
内容介绍0.学习目标1.双向链表简介1.1双向链表介绍1.2双向链表结点类1.3双向链表优缺点2.双向链表实现2.1双向链表的初始化2.2获取双向链表长度2.3读取指定位置元素2.4
本文主要介绍了Python实现批量压缩文件/文件夹zipfile的使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
需求:将utf-8格式的文件转换成gbk格式的文件实现代码如下:defReadFile(filePath,encoding="utf-8"):withcodecs open(filePath,"r",encodi
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008