博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
重温二分查找算法
阅读量:6241 次
发布时间:2019-06-22

本文共 908 字,大约阅读时间需要 3 分钟。

二分查找在学习算法的时候会涉及到,算是一个基本的分治思想,对于算法的实现大家也都是很熟悉的,但是这个时候真会犯眼高手低的毛病。不信你自己试试,看你能够在段时间内写出可运行的二分查找算法。
二分查找算法的思想非常易于理解,但是能够写出一个准确的二分查找程序绝非一个很简单的事情,从历史上来看,二分思想早在1946年就出现了,但是第一个完全正确的二分查找算法确实在1962年出现,计算机专家曾说过,90%以上的计算机专家不能再2个小时内写出完全正确的二分查找算法。我反正是应了这句话,不过我不是计算机专家。
我们来看一个比较标准的二分查找算法

点击(此处)折叠或打开

  1. package new_test;
    public class BinarySearch {
    int arr[];
    public static void main(String args[]){
    test();
    }
    public int binarySearch(int t,int[] arr){
    int left=0;
    int right=arr.length;
    int middle;
    while(left middle=(left+right)/2;
    if(t==arr[middle]){
    return middle;
    }
    if(t>arr[middle]){
    left=middle+1;
    }
    if(t right=middle-1;
    }
    }
    return -1;
    }
    public static void test(){
    int[] arr=new int[]{1,2,5,7,8,10,11,15,19,20};
    System.out.println( new BinarySearch().binarySearch(8, arr));
    }
    }
运行结果是4,即arr[4]=8
其实这个算法还有一些值得思考的细节。比如求得两个数之和的平均数
如果直接写为middle=(left+right)/2就很可能出现数值溢出的情况。
可以使用下面的形式来避免,算法博大精深,细节决定成败。
middle=left+(right-left)/2;

转载地址:http://kpcia.baihongyu.com/

你可能感兴趣的文章
Redis 数据结构的底层实现 (一) RealObject,embstr,sds,ziplist,quicklist
查看>>
SQL语句注入的问题
查看>>
jQueryEasyUI Messager基本使用
查看>>
【C语言学习趣事】_33_关于C语言和C++语言中的取余数(求模)的计算_有符号和无符号数的相互转换问题...
查看>>
Tensorboard教程:显示计算图中节点信息
查看>>
java 线程基本概念 可见性 同步
查看>>
Java:JUnit包
查看>>
unity_快捷键
查看>>
洛谷P3358 最长k可重区间集问题(费用流)
查看>>
洛谷P1251 餐巾计划问题(费用流)
查看>>
Beta冲刺(2/5)(麻瓜制造者)
查看>>
vs2012编码的UI测试使用教程
查看>>
android 在非UI线程更新UI仍然成功原因深入剖析
查看>>
清北NOIP训练营集训笔记——图论
查看>>
oracle ORA-00060死锁查询、表空间扩容
查看>>
转载自https://github.com/jsfront/src/blob/master/css.md
查看>>
MySQL索引优化分析(上)
查看>>
jquery $().each,$.each的区别
查看>>
sql server 2000/2005 游标的使用操作(转)
查看>>
Tomcat 部署 Web 通过 ip 直接访问项目
查看>>