算法简介之二分查找

其实日常的开发中,因为更多的是复杂的业务逻辑,但分解之后,其实用到的算法知识并不多,更何况作为一名Java程序员,常用类库中已经实现了一些算法,例如排序,Hash等,但是随着开发的深入,我意识到算法其实不只是为了去解决一种特定的问题,也是开阔思维的一种很棒的办法,特开此篇,一方面学习,一方面记录。

其实二分查找的思想在生活中很多地方都有运用,比如我们猜数的时候,例如给定0-4000的范围选出一个数字,然后让你猜是哪一个,然后根据你每次回答的数字来给出高了,低了,最后直至猜到该数字,相信大多数人都会直接从中间开始,因为这样在第一次回答之后,就去除了一半的范围,然后再依次去除一半,直到最后得出准确答案,其实这就是二分法的思想,如果按照最多次数来查找,4000次使用二分法相当于 2的X次幂 = 4000,X四舍五入大约是12次,也就是说12次我们就可以把整个4000个数字筛选完,

所以用大O表示法来标识二分法的运行时间是O(log2N),而简单查找(顺序查找)是O(N)。

但在这之中其实我们隐含了一个前提:

该数列是有序的

JAVA版实现(自己实现的,可能有问题,但是思想上应该没错,是从小到大的列表):

 private Integer dichotomy(List<Integer> list, int param) {
    int low = 0 ;
    int high = list.size() - 1 ;
    while (high  >=  low) {
        int mid = (high + low) / 2;
        Integer integer = list.get(mid);
        if (param == integer) {
            return mid;
        } else if (param < integer) {
            high = mid - 1;
        } else if (param > integer) {
            low = mid + 1;
        }
    }
    return null;
}

该方法会返回给定数字在已存列表中的位置。如果不存在则返回null。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值