day4 递归二分法查找
现有一个序列,data=[for i in range(1,5000,3)],现在要求看一个数是否在列表中存在,我们知道,我们可以使用in或__contains__()的方法,判断一个值是否在列表中,但是列表也是一个一个遍历,看是否与列表中的某个值相等,如果不等则返回False;如果在,则返回True。
def binary_search(data,find_n):
mid_n = int(len(data)/2)
#递归必须有结束条件,这里的结束条件是,当只有两个长度的时候必须结束
if mid_n > 1: #递归的结束条件,如果只有两个元素的时候就没有必要进行再一次判断了
if data[mid_n] > find_n: #如果中间值大于查找值,说明在列表的左侧
print(data[:mid_n])
binary_search(data[:mid_n],find_n) #再次进行递归,缩小范围
elif data[mid_n] < find_n: #如果中间值小于查找值,说明在中间值的右侧
print(data[mid_n:])
binary_search(data[mid_n:],find_n) #递归,缩小范围
elif data[mid_n] == find_n: #如果中间值等于查找值,说明在列表中
print("%s在列表data中" %find_n)
elif mid_n == 1:
#我们知道,递归结束的时候,有两种情况,第一种是长度等于2,另外一种情况是长度等于3
print(data)
if len(data) == 2: #如果列表长度等于2,那么就判断是否有一个等于查找值,
if data[0] == find_n or data[1] == find_n:
print("%s在列表data中" % find_n)
else:
print("%s不在列表data中" % find_n)
else:
#列表长度等于3的时候的情况,逐个进行比较
if data[0] == find_n or data[1] == find_n or data[2] == find_n:
print("%s在列表data中" %find_n)
else:
print("%s不在列表data中" %find_n) if __name__ == "__main__":
data = [i for i in range(1,5008,4)]
binary_search(data,10)
上面流程图中,详细描述了代码运转的过程,我们知道,如果使用递归,那么遍历列表的时候只有两种情况,要么查找的值在列表中,要么不在列表中,并且,到最后,列表的长度只可能为1和2,这个时候我们要分情况去考虑,上面总共有三种情况出现,(1)遍历过程中中间值正好就是我们要查找的值;(2)列表长度为1,那最后剩下的元素进行比较,这个时候一半就是小于等于最小值或者大于等于最大值;(3)列表的长度为2,这个时候情况也一样,要么大于等于最大值,小于等于最小值;出现列表1和2长度的原因是data原数据的长度有关,因为原数据有长度有单数和偶数之分,因此结果也会出现这两种情况,上述三种情况都要具体分析,不然肯定会报错。有些人可能输入的本来就是列表中的值肯定可以找的到,但如果不是的时候会报错。又或者奇数的时候对,偶数的时候错;偶数的时候对,奇数的时候错。
day4 递归二分法查找的更多相关文章
- python --- 14 递归 二分法查找
一.递归 1.函数自己调用自己 2.官方说明最大深度1000,但跑不到1000,要看解释器, 实测998 3.使⽤递归来遍历各种树形结构 二. 二分法查找 掐头结尾取中间 , 必须是有序序列 ...
- Java基础(50):二分法查找的非递归实现和递归实现(完整代码可运行,参考VisualGO理解更佳)
一.概念 二分查找算法也称折半查找,是一种在有序数组中查找某一特定元素的搜索算法. 二.算法思想 搜素过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束:如果某一特定元素大于或者 ...
- python 内置函数(二) 进阶函数 递归内容及二分法查找 知识点
1,lambda: 匿名函数 2.sorgted() 排序函数 3,filter() 过滤函数 筛选 4,map() 映射函数 5.递归 6.二分法 一. 匿名函数: lambda lamb ...
- Python【day 14-4】sorted filter map+递归文件夹+二分法查找
def func(x): #普通函数 return x*x ret1 = func(10) #匿名函数 f = lambda x:x*x # 匿名函数写法: 匿名函数名=lambda 参数:返回值 ' ...
- python3 二分法查找
'''二分法查找有序列表掐头去尾取中间查找列表中xx在不在列表中,在,则返回索引值'''# lst = [1, 4, 6, 8, 9, 21, 23, 26, 35, 48, 49, 54, 67, ...
- day17递归函数(二分法查找)
递归函数: 如果函数包含了对其自身的调用,该函数就是递归的: example 1:二分法查找的实现: def find_recursion(l,aim,start=0,end=None): #end不 ...
- python - 递归 二分法
一.一些内置函数 1.revsered 翻转,返回的是迭代器 # 将 s 倒置 s = '不是上海自来水来自海上' # 方法一 print(s[::-1]) # 方法二 s1 = reversed( ...
- python之路--递归, 二分法
一 . 递归 自己调用自己, 递归的入口(参数) 和 出口(return), 树形结构的遍历. def func(): print("我是递归") func() func() ...
- Day14--Python--函数二,lambda,sorted,filter,map,递归,二分法
今日主要内容:1. lambda 匿名函数 lambda 参数: 返回值-------------------------------------def square(x): return x**2 ...
随机推荐
- HTTP协议格式【转】
原文链接:https://www.jianshu.com/p/8fe93a14754c 一.URI结构 HTTP使用统一资源标识符(URI)来传输数据和建立连接.URL(统一资源定位符)是一种特殊种类 ...
- mybatis sql使用经验总结
1.where 后面如果有动态sql,可以添加一个1=1条件,然后在后面添加动态sql语句,里面添加AND 例如: <select id="queryBizMonitorHistory ...
- selenium - webdriver - cookie操作
WebDriver提供了操作Cookie的相关方法,可以读取.添加和删除cookie信息. WebDriver操作cookie的方法: get_cookies(): 获得所有cookie信息. get ...
- 洛谷P1029 最大公约数和最小公倍数问题
题目描述 输入二个正整数x0,y0(2<=x0<100000,2<=y0<=1000000),求出满足下列条件的P,Q的个数 条件: 1.P,Q是正整数 2.要求P,Q以x0为 ...
- mac pro电脑怎么安装rabbitmq
第一:依次执行以下命令: 1. /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/inst ...
- Netfilter之连接跟踪实现机制初步分析
Netfilter之连接跟踪实现机制初步分析 原文: http://blog.chinaunix.net/uid-22227409-id-2656910.html 什么是连接跟踪 连接跟踪(CONNT ...
- OpenCV---超大图像二值化和空白区域过滤
超大图像的二值化方法 1.可以采用分块方法, 2.先缩放处理就行二值化,然后还原大小 一:分块处理超大图像的二值化问题 def big_image_binary(image): print(image ...
- Android 统一配置依赖管理
Android Studio中默认就是使用Gradle来构建管理工程的,当我们在工程构建过程中创建了多个Module时,就可能存在一个问题,那就是每个Module以及Module中一些公用库的依赖存在 ...
- bzoj 2453: 维护队列
2453: 维护队列 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1079 Solved: 503[Submit][Status][Discuss ...
- 成为优秀 Node.js 程序员的10个习惯
JavaScript出现近二十年了,但由于其有些问题不能解决,使得像Python和Ruby这一类的语言很吸引人,这些问题包括命令行接口.交互式开发环境.包的管理和没有一个有组织开源社区等.幸亏Node ...