在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
二分法检索变种实现代码怎么写?二分法中每次排除都可以排除掉一半的情况,这样寻找效率很高。之所以叫二分,因为每次排除都把所有的情况分成"可能"和"不可能"两种,然后抛弃所有"不可能"的情况。
二分法真的不简单,尤其是二分法的各个变种。最简单的二分法,就是从一个排好序的数组之查找一个key值。如下面的程序:
这个程序,相信只要是一个合格的程序员应该都会写。稍微注意一点, 每次移动left和right指针的时候,需要在mid的基础上+1或者-1, 防止出现死循环, 程序也就能够正确的运行。
但如果条件稍微变化一下, 你还会写吗?如,数组之中的数据可能可以重复,要求返回匹配的数据的最小(或最大)的下标;更近一步, 需要找出数组中第一个大于key的元素(也就是最小的大于key的元素的)下标,等等。这些,虽然只有一点点的变化,实现的时候确实要更加的细心。下面列出了这些二分检索变种的实现。
1、找出第一个与key相等的元素
2、找出最后一个与key相等的元素
3、查找第一个等于或者大于Key的元素
4、查找第一个大于key的元素
5、查找最后一个等于或者小于key的元素
6、查找最后一个小于key的元素
总结:
算法:当数据量很大适宜采用该方法。采用二分法查找时,数据需是排好序的。
基本思想:假设数据是按升序排序的,对于给定值key,从序列的中间位置k开始比较,
如果当前位置arr[k]值等于key,则查找成功;
若key小于当前位置值arr[k],则在数列的前半段中查找,arr[low,mid-1];
若key大于当前位置值arr[k],则在数列的后半段中继续查找arr[mid+1,high],
直到找到为止,时间复杂度:O(log(n))。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
学C++应该看哪些书?零基础入门书籍推荐
近些年来,虽然各种编程语言层出不穷,但是C++的地位依然比较稳固,在某些领域具有不可替代的作用。那么学C++应该看哪些书?本文就是为零基础入门的小伙伴推荐十本书籍。
7398
2019-08-12 20:19:43
编程入门先学什么语言?
编程入门先选一门简单的语言进行学习,对编程有一个初步的认识,建议选择C、Java、Python,这些都是不错的入门语言重要的是掌握编程思想、找到编程感觉,而不是死记硬背语言本身,很多语言是一致的。
13879
2019-11-27 14:38:57
IT程序员入门必须要学会的是什么?
IT程序员入门必须要学会的是什么?入门需要具备一定的英语基础、计算机体系结构和汇编语言、计算机操作系统原理、数据结构和算法、软件工程、Windows程序设计等相关知识点。
6319
2020-03-02 16:39:25
学IT培训学校怎么选?
许多同学在开始打算学编程时,都在培训学校的选择上犯难。IT培训学校多种多样,教学方式也各不相同。许多培训学校也推出了各种网课,视频直播也是当下大热授课方式之一。应该对自己有明确的定位,根据自身有无基础来判断,课程的学习方式。
3279
2020-06-05 14:34:52
Android sdk环境搭建详细步骤讲解
Android sdk环境搭建的前提条件是必须先在本机安装Java环境。满足了这一条件之后,大家就可以开始按照下面的Android sdk环境搭建详细步骤讲解,来慢慢操作了。希望本文可以对大家有所帮助~
4547
2020-07-21 16:50:24