Python递归函数 二分查找算法实现解析


Posted in Python onAugust 12, 2019

一、初始递归

递归函数:在一个函数里在调用这个函数本身。

递归的最大深度:998

正如你们刚刚看到的,递归函数如果不受到外力的阻止会一直执行下去。但是我们之前已经说过关于函数调用的问题,每一次函数调用都会产生一个属于它自己的名称空间,如果一直调用下去,就会造成名称空间占用太多内存的问题,于是python为了杜绝此类现象,强制的将递归层数控制在了997(只要997!你买不了吃亏,买不了上当...).

拿什么来证明这个“998理论”呢?这里我们可以做一个实验:

def foo(n):
  print(n)
  n += 1
  foo(n)
foo(1)

由此我们可以看出,未报错之前能看到的最大数字就是998.当然了,997是python为了我们程序的内存优化所设定的一个默认值,我们当然还可以通过一些手段去修改它:

import sys
print(sys.setrecursionlimit(100000))

我们可以通过这种方式来修改递归的最大深度,刚刚我们将python允许的递归深度设置为了10w,至于实际可以达到的深度就取决于计算机的性能了。不过我们还是不推荐修改这个默认的递归深度,因为如果用997层递归都没有解决的问题要么是不适合使用递归来解决要么是你代码写的太烂了~~~

看到这里,你可能会觉得递归也并不是多么好的东西,不如while True好用呢!然而,江湖上流传这这样一句话叫做:人理解循环,神理解递归。所以你可别小看了递归函数,很多人被拦在大神的门槛外这么多年,就是因为没能领悟递归的真谛。而且之后我们学习的很多算法都会和递归有关系。来吧,只有学会了才有资本嫌弃!

二、递归示例讲解

这里我们又要举个例子来说明递归能做的事情。

例一:

现在你们问我,alex老师多大了?我说我不告诉你,但alex比 egon 大两岁。

你想知道alex多大,你是不是还得去问egon?egon说,我也不告诉你,但我比武sir大两岁。

你又问武sir,武sir也不告诉你,他说他比太白大两岁。

那你问太白,太白告诉你,他18了。

这个时候你是不是就知道了?alex多大?

1 金鑫 18
2 武sir 20
3 egon 22
4 alex 24

你为什么能知道的?

首先,你是不是问alex的年龄,结果又找到egon、武sir、太白,你挨个儿问过去,一直到拿到一个确切的答案,然后顺着这条线再找回来,才得到最终alex的年龄。这个过程已经非常接近递归的思想。我们就来具体的我分析一下,这几个人之间的规律。

age(4) = age(3) + 2 
age(3) = age(2) + 2
age(2) = age(1) + 2
age(1) = 40

那这样的情况,我们的函数怎么写呢?

def age(n):
  if n == 1:
    return 40
  else:
    return age(n-1)+2
print(age(4))

如果有这样一个列表,让你从这个列表中找到66的位置,你要怎么做?

l = [2,3,5,10,15,16,18,22,26,30,32,35,41,42,43,55,56,66,67,69,72,76,82,83,88]

你说,so easy!

l.index(66)...

我们之所以用index方法可以找到,是因为python帮我们实现了查找方法。如果,index方法不给你用了。。。你还能找到这个66么?

l = [2,3,5,10,15,16,18,22,26,30,32,35,41,42,43,55,56,66,67,69,72,76,82,83,88]
i = 0
for num in l:
  if num == 66:
    print(i)
  i+=1

上面这个方法就实现了从一个列表中找到66所在的位置了。

但我们现在是怎么找到这个数的呀?是不是循环这个列表,一个一个的找的呀?假如我们这个列表特别长,里面好好几十万个数,那我们找一个数如果运气不好的话是不是要对比十几万次?这样效率太低了,我们得想一个新办法。

二分查找算法

l = [2,3,5,10,15,16,18,22,26,30,32,35,41,42,43,55,56,66,67,69,72,76,82,83,88]

你观察这个列表,这是不是一个从小到大排序的有序列表呀?

如果这样,假如我要找的数比列表中间的数还大,是不是我直接在列表的后半边找就行了?

Python递归函数 二分查找算法实现解析

这就是二分查找算法!

那么落实到代码上我们应该怎么实现呢?

简单版二分法

l = [2,3,5,10,15,16,18,22,26,30,32,35,41,42,43,55,56,66,67,69,72,76,82,83,88]
def func(l,aim):
  mid = (len(l)-1)//2
  if l:
    if aim > l[mid]:
      func(l[mid+1:],aim)
    elif aim < l[mid]:
      func(l[:mid],aim)
    elif aim == l[mid]:
      print("bingo",mid)
  else:
    print('找不到')
func(l,66)
func(l,6)

升级版二分法

l1 = [1, 2, 4, 5, 7, 9]
def two_search(l,aim,start=0,end=None):
  end = len(l)-1 if end is None else end
  mid_index = (end - start) // 2 + start
  if end >= start:
    if aim > l[mid_index]:
      return two_search(l,aim,start=mid_index+1,end=end)
    elif aim < l[mid_index]:
      return two_search(l,aim,start=start,end=mid_index-1)

    elif aim == l[mid_index]:
      return mid_index
    else:
      return '没有此值'
  else:
    return '没有此值'
print(two_search(l1,9))

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python下的Mysql模块MySQLdb安装详解
Apr 09 Python
在Python中使用列表生成式的教程
Apr 27 Python
python中黄金分割法实现方法
May 06 Python
Python3 加密(hashlib和hmac)模块的实现
Nov 23 Python
分析python切片原理和方法
Dec 19 Python
Python MySQLdb 使用utf-8 编码插入中文数据问题
Mar 13 Python
selenium使用chrome浏览器测试(附chromedriver与chrome的对应关系表)
Nov 29 Python
Django框架模板语言实例小结【变量,标签,过滤器,继承,html转义】
May 23 Python
Python3.x+迅雷x 自动下载高分电影的实现方法
Jan 12 Python
Python使用type动态创建类操作示例
Feb 29 Python
Django实现前台上传并显示图片功能
May 29 Python
Python判断变量是否是None写法代码实例
Oct 09 Python
基于Python安装pyecharts所遇的问题及解决方法
Aug 12 #Python
Django实现发送邮件找回密码功能
Aug 12 #Python
使用pyecharts生成Echarts网页的实例
Aug 12 #Python
10分钟教你用python动画演示深度优先算法搜寻逃出迷宫的路径
Aug 12 #Python
python利用itertools生成密码字典并多线程撞库破解rar密码
Aug 12 #Python
Python实现网页截图(PyQT5)过程解析
Aug 12 #Python
python实现知乎高颜值图片爬取
Aug 12 #Python
You might like
PHP合并数组+号和array_merge的区别
2015/06/25 PHP
HR vs ForZe BO3 第一场 2.13
2021/03/10 DOTA
JavaScript DOM学习第一章 W3C DOM简介
2010/02/19 Javascript
javascript中的关于类型转换的性能优化
2010/12/14 Javascript
JS实现文字链接感应鼠标淡入淡出改变颜色的方法
2015/02/26 Javascript
js实现文本框选中的方法
2015/05/26 Javascript
javascript单例模式的简单实现方法
2015/07/25 Javascript
JS实现的图片预览插件与用法示例【不上传图片】
2016/11/25 Javascript
jQuery Validate验证表单时多个name相同的元素只验证第一个的解决方法
2016/12/24 Javascript
深入理解JavaScript继承的多种方式和优缺点
2017/05/12 Javascript
vue弹窗消息组件的使用方法
2020/09/24 Javascript
JavaScript面向对象程序设计创建对象的方法分析
2018/08/13 Javascript
前端防止用户重复提交js实现代码示例
2018/09/07 Javascript
nodejs异步编程基础之回调函数用法分析
2018/12/26 NodeJs
详解50行代码,Node爬虫练手项目
2019/04/22 Javascript
vue中通过使用$attrs实现组件之间的数据传递功能
2019/09/01 Javascript
修改layui的后台模板的左侧导航栏可以伸缩的方法
2019/09/10 Javascript
JavaScript实现前端倒计时效果
2021/02/09 Javascript
Python匹配中文的正则表达式
2016/05/11 Python
Python解决抛小球问题 求小球下落经历的距离之和示例
2018/02/01 Python
在python2.7中用numpy.reshape 对图像进行切割的方法
2018/12/05 Python
Python生成指定数量的优惠码实操内容
2019/06/18 Python
深入了解Python在HDA中的应用
2019/09/05 Python
Django框架ORM数据库操作实例详解
2019/11/07 Python
通过celery异步处理一个查询任务的完整代码
2019/11/19 Python
解决TensorFlow训练内存不断增长,进程被杀死问题
2020/02/05 Python
Django前后端分离csrf token获取方式
2020/12/25 Python
NEW LOOK官网:英国时装零售巨头之一,快时尚品牌
2017/01/11 全球购物
Agoda台湾官网:国内外订房2折起
2018/03/20 全球购物
台湾专柜女包:KINAZ
2019/12/26 全球购物
出国导师推荐信
2014/01/16 职场文书
党员批评与自我批评总结
2014/10/15 职场文书
Python列表删除重复元素与图像相似度判断及删除实例代码
2021/05/07 Python
PHP面试题 wakeup魔法 Ezpop pop序列化与反序列化
2022/04/11 PHP
使用Postman测试需要授权的接口问题
2022/06/21 Java/Android
JavaScript实现九宫格拖拽效果
2022/06/28 Javascript