二分查找以及时间、空间复杂度

package com.wei.demo.Annotation;

/**
 * 二分查找算法Java:循环方法和递归方法
 * 思想:我们查找的数组范围是low(0)~high(len-1)。每次查找中间的元素,我们猜测的数字是guess=(low+high)/2;
 * 实际数字为item,如果猜测数字guess小于item,那范围变为:guess+1~high,low=guess+1位置开始;
 * 如果猜测数字guess大于item,那就范围变为low~guess-1
 * 数组:必须是有序的
 * 结果:返回想要数字的位置
 */
public class binary_search {

    public static void main(String[] args) {
        int[] array = {1, 2, 33, 55, 66, 88, 99, 567, 789, 999,1000,10001,100002};
       // index(array,item);
        System.out.println("循环方法猜测数字的位置为:"+index(array,33));
        System.out.println("递归方法猜测数字的位置为:"+binarySearch(array,0,array.length-1,33));
    }

 /**
     * 循环的方法
     * @param array
     * @param key
     * @return
     */
    public static int index(int array[],int key){

        int low = 0;
        int high = array.length - 1;
        int middle = 0;
       // int guess = array[middle];//猜测的数字

        if (key < array[low] || key > array[high] || low >high){
            return -1;
        }
        while (low <=high){ //循环结束的条件是左边等于右边,那就是中间要找的数字
            middle = (low + high)/2;
            int guess = array[middle];//猜测的数字
            if (guess < key){ //如果猜测的数字小于实际数字,low就要从middle+1开始
                low = middle + 1;
            }else if (guess > key){//如果猜测的数字大于实际数字,那么high就要从middle-1开始
                high = middle - 1;
            }else{
                return middle;
            }

        }
        return -1;
    }
    /***
     *递归的方式
     */
    public static int binarySearch(int[] arrays,int low,int high,int key){
        if (key < arrays[low] || key > arrays[high] || low >high){
            return -1;
        }
        int middle = (low + high) / 2;
        if (arrays[middle] > key){
           return  binarySearch(arrays, low, middle - 1, key);
        }else if (arrays[middle] < key){
           return  binarySearch(arrays, middle + 1, high, key);
        }else{
            return middle;
        }

    }
}

1.时间复杂度分析:

最坏的情况下两种方式时间复杂度一样:O(log2 N)


最好情况下为O(1)

2.空间复杂度分析:

算法的空间复杂度并不是计算实际占用的空间,而是计算整个算法的辅助空间单元的个数
循环方式:
  由于辅助空间是常数级别的所以:
  空间复杂度是O(1);
递归方式:

递归的次数和深度都是log2 N,每次所需要的辅助空间都是常数级别的:
 空间复杂度:O(log2N )
 

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阳光不锈@

如果有帮助的话,打赏一下吧

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值