在线客服
扫描二维码
下载博学谷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))。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
IT是什么行业?IT行业发展史
IT是什么行业?IT行业发展史。IT是Information Technology英文的缩写,全称含义为“信息技术”涵盖的范围很广,主要包括:现代计算机、网络通讯等信息领域的技术。IT互联网技术是指在计算机技术的基础上开发建立的一种信息技术。互联网技术的普遍应用,是进入信息社会的标志。在不同的场景中对此有不同解释。
11122
2019-07-29 17:03:17
程序员常用的十款开发工具推荐
工欲善其事必先利其器。对于程序员来讲,好用的开发工具可以大大提高开发效率。本文将向大家推荐程序员常用的十款开发工具,希望能帮助大家更加优雅地写出代码。这些工具分别是Arthas、ChaosBlade、Docsite、PTS、AHAS、Druid、HandyJSON、Freeline、Cloud Toolkit和Mockito,感兴趣的话就一起来看看吧!
6347
2019-11-21 14:52:28
IT基础知识有哪些?IT行业前景如何吗?
IT这个词相信大家都不陌生,全称为Internet Technology,中文就是指信息技术 。在科技技术和网络技术日益完善的当代,人们对于科技人才的需求也是愈来越大,那么掌握一定的IT基础知识,成为专业的IT工作人员 ,前途将不可估量。
4393
2020-05-28 14:19:12
传智博学谷“狂野系列”在线课程成绩单喜人
传智博学谷“狂野系列”在线课程成绩单喜人,IT互联网行业发展快速,技能知识点更新迭代较快,程序员们保持学习才能在行业中具有核心竞争力。程序员为了寻求更高的职级和更好的待遇,采用最多的方式是学习热点技术。
3304
2022-04-19 13:51:40
万物互联是什么?会带来哪些改变?
万物互联是什么?会带来哪些改变?互联网技术和通讯协议的快速发展,让“万物互联”不再遥不可及。物联网从使用用户来分可以分为C端用户和B端用户。其实物联网在面向B端的场景已经发展得较为成熟了已经基本实现了“万物”互联,而且在相应垂域形成了业务的完整闭环。
3122
2022-05-18 14:51:03