python --- 二分查找算法

二分查找法:在我的理解中这个查找方法为什么会叫二分呢,我认为是将要查询的一个列表分成了两份,然后在利用某个值来进行比较,在一个不断循环的过程中来找出我们要找的某一个值。

废话不多说,先上代码:

 1 def twofenfind(lst, target):
 2     left = 0
 3     right = len(lst) - 1
 4 
 5     while target in lst:
 6         mid = (left + right) // 2
 7         if target > lst[mid]:
 8             left = mid + 1
 9 
10         elif target < lst[mid]:
11             right = mid - 1
12 
13         else:
14             return mid
15     return None
16 
17 
18 
19 print(twofenfind([1, 2, 3 ,4, 7], 3))
# 代码有些地方可能会有歧义,但这也仅仅只是我个人的一些理解(如有错误还请指正)。

二分查找发是一个效率很高的查找法,但是被查找的数据必须是有序的。

首先,将待查找target值与有序列表lst[0]到lst[n - 1]的中间位置——记为mid上的结点的关键字进行比较,如果相等就完成查找;否则,若lst[mid]>target,则说明待查找的数只可能在列表左边

lst[0]-lst[mid - 1]中,只需要在左边的列表中进行查找;若lst[mid] > x,则在右边的列表lst[mid + 1] 到 lst[n - 1]中继续进行查找,这样经过一次,关键字的比较就缩小了一半的查找区间。

然后继续按照上面的方法进行查找,然后知道找到关键字为target的元素或者当前查找区间为空(即表明查找失败)为止。

 

下面测试一下,以查找target:13为例: 

当中取mid的关键字和target进行比较,很显然13 < 17,所以要查找的13应该是在前半部分的,所以下次查找的区间应该是在[0,5],即left的值不变仍然为0,right的值变为mid - 1 = 5,所以

mid = len(right + left) // 2 = 2(这里要进行整除)

 

取11和13进行比较,显然13 > 11, 所以要查找的值应该是在11后面的,所以left就变为了mid + 1 ,right的值仍然不变,取得最终的值mid = 3

取mid指示的位置的关键字13和target进行比较,结果相等,就说明查找成功了,所以target在列表中的位置即为mid所指示的位置。(我是按照索引来查找的)

 

转载于:https://www.cnblogs.com/tulintao/p/10748541.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/251882.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

面试题

1. block 的作用由来&#xff0c;跟delegate的区别。 2. swift 的枚举。 3. iOS保存一个对象。转载于:https://www.cnblogs.com/studyNT/p/7499779.html

ssm框架下文件上传

springmvc实现文件上传的步骤&#xff1a; 1.页面上&#xff0c;通过input来准备file组件&#xff0c;该标签&#xff0c;必须给定name属性值 同时&#xff0c;要求form表单必须给定一个属性&#xff1a;enctype"multipart/form-data" 2.在pom.xml文件中&#xff0c;…

MySQL via EF6 的试用报告

MySQL via EF6 的试用报告1、如何通过 EF6 来连接 MySQL&#xff1f;2、如何通过 EF6 来实现 CRUD&#xff1f;2.1、Create 添加2.2、Retrieve 查询2.3、Update 修改2.4、Delete 删除3、如何更好的运用 EF6 来完成工作&#xff1f;3.1、传说中 EF 的三种模式3.2、EF6 执行原生 …

Java暑假作业

一.《大护法》观影有感 ... 从预告开始就期待着这部影片&#xff0c;在看过一遍后又忍不住二刷&#xff0c;影片观看至第二遍后&#xff0c;对于全片的脉络也更清晰了一点&#xff0c;虽然打着暴力美学的旗子&#xff0c;但《大护法》偏偏更文艺一些。文艺片是没有对错的&a…

使用EasyNetQ组件操作RabbitMQ消息队列服务

RabbitMQ是一个由erlang开发的AMQP(Advanved Message Queue)的开源实现&#xff0c;是实现消息队列应用的一个中间件&#xff0c;消息队列中间件是分布式系统中重要的组件&#xff0c;主要解决应用耦合&#xff0c;异步消息&#xff0c;流量削锋等问题。实现高性能&#xff0c;…

context-param和init-param的区别

http://www.cnblogs.com/hzj-/articles/1689836.html 转载于:https://www.cnblogs.com/wangc04/p/7501054.html

TensorFlow 1.12.2 发布,修复 GIF 构造安全漏洞

开发四年只会写业务代码&#xff0c;分布式高并发都不会还做程序员&#xff1f; TensorFlow 1.12.2 发布了&#xff0c;此处本修复了一个潜在的安全漏洞&#xff1a; 精心设计的 GIF 图像可以在解码过程中产生空指针解引用更新说明&#xff1a; https://github.com/tensorflo…

【教程】如何在标签打印工具TFORMer Designer中自定义布局?

TEC-IT的在线标签生成器TFORMer Designer提供标签打印服务&#xff0c;并提供即用型行业标签模板作为Web服务。使用此软件&#xff0c;您可以在几秒钟内创建您自己的标签和表格或在工业和物流业中使用即时可用的模板。TFORMer Designer的最新更新现在允许使用自定义标签布局。 …

对象变为指定格式的数组

拿到的对象的格式&#xff08;一个对象里面都好多属性&#xff09; 想要转换成的数据格式&#xff08;一个数组里面有好多个对象&#xff0c;每个对象有一个id和name的属性&#xff09; 如何处理的 selectionChange(val) { // 列表选择var dynamicTags1 [];var arr[]for(var i…

bootstrapValidator remote 验证问题

1 加载jQuery和bootstrap.min.js 后引入bootstrapValidator.min.js字段验证之remote 远程验证(类似ajax验证)&#xff0c;返回值必须是 {"valid":true}{"valid":false} true表示 验证通过 false 表示验证不通过。 当添加remote 验证后&#xff0c;验证通过…

世界顶级的程序员们告诉你:这些书都是你应该读的

在很早之前就想整理一份来自经验丰富的顶级程序员推荐阅读的书籍清单&#xff0c;全栈工程师Dmitry Shvetsov整理了Bob叔以及Jeff Atwood and DHH等世界知名程序员曾经在博客中推荐过的书单&#xff0c;下面我们就一起来看看深受大神们青睐的书籍都是哪些?世界顶级的程序员们告…

《20170911-构建之法:现代软件工程-阅读笔记》

第一章&#xff1a; 介绍软件工程和软件的关系&#xff0c;软件程序软件工程。 软件工程是把系统的、有序的、可量化的方法应用到软件的开发、运营和维护上的过程。 计算机科学这一学术领域可以分为以下这些偏理论的领域&#xff1a; 1.计算机理论 2.信息和编码理论 3.算法和数…

mysql学习(2)索引的本质

2019独角兽企业重金招聘Python工程师标准>>> 问题&#xff1a;SQL查询慢怎么办&#xff1f; 优化手段&#xff0c;加索引。 索引是帮助MYSQL高效的获取数据的排好序的数据结构。 问题&#xff1a;索引结构为什么使用Btree而不使用二叉树&#xff0c;红黑树或者HASH结…

bzoj4245: [ONTAK2015]OR-XOR

一道很有意思的题目。 先求一次前缀和&#xff0c;可以发现答案是 (sum[0] xor sum[x1])or(sum[x1] xor sum[x2])or(sum[x2] xor sum[x3])or……or(sum[m-1] xor sum[n]) 然后其实&#xff08;a xor b&#xff09;or b a or b 那么sum[0]0,可以把柿子变成 sum[x1] or sum[x2] o…

移动端常见的一些兼容性问题

1、安卓浏览器看背景图片&#xff0c;有些设备会模糊。 是devicePixelRatio作怪&#xff0c;因为手机分辨率太小&#xff0c;如果按照分辨率来显示网页&#xff0c;这样字会非常小&#xff0c;所以苹果当初就把iPhone 4的960*640分辨率&#xff0c;在网页里只显示了480*320&…

go-变量

这次我们学习一下golang语言 gitee: go-study 定义 定义的变量或者函数必须用到(pakeage内的全局除外) var a int // 默认为0 var b string //默认为"" fmt.Printf("%d %q\n",a, s) 复制代码直接定义可以不写类型(int..)go会自行判断 var a, b 3, 4 var …

CSS3:CSS3 文本效果

ylbtech-CSS3&#xff1a;CSS3 文本效果1.返回顶部 1、CSS3 文本效果 CSS3 文本效果 CSS3中包含几个新的文本特征。 在本章中您将了解以下文本属性&#xff1a; text-shadowbox-shadowtext-overflowword-wrapword-break浏览器支持 属性 text-shadow4.010.03.54.09.5box-sha…

洛谷 P2296 寻找道路

题目描述 在有向图G 中&#xff0c;每条边的长度均为1 &#xff0c;现给定起点和终点&#xff0c;请你在图中找一条从起点到终点的路径&#xff0c;该路径满足以下条件&#xff1a; 1 &#xff0e;路径上的所有点的出边所指向的点都直接或间接与终点连通。 2 &#xff0e;在满足…

Feature Preprocessing on Kaggle

刚入手data science, 想着自己玩一玩kaggle&#xff0c;玩了新手Titanic和House Price的 项目, 觉得基本的baseline还是可以写出来&#xff0c;但是具体到一些细节&#xff0c;以至于到能拿到的出手的成绩还是需要理论分析的。 本文旨在介绍kaggle比赛到各种原理与技巧&#xf…

十天冲刺-04

昨天&#xff1a;完成了日历界面的部署&#xff0c;并且能够获取到选中的日期 今天&#xff1a;完成根据日期查找消费记录功能 问题&#xff1a;日历界面占用屏幕太多&#xff0c;后期会进行调整转载于:https://www.cnblogs.com/liujinxin123/p/10760254.html