二分法逻辑及实现

概念

二分法是通过递归的方法,不断地以二分的形式,缩小比较空间,以达到快速查找某个值是在列表中哪个位置的方法

逻辑

  1. 根据传入的最小索引范围start和最大索引范围计算mid中间位置:
    mid = (start+end+1)/2
  2. 判断mid索引对应的值是否等于要求的值,是则返回对应下标,否则继续比较
  3. mid索对应值大于要求的值
    则从start~mid-1中进行查找
  4. 否则从 mid+1~end中进行查找
  5. 为何是从mid-1或mid+1内进行查找?
    因为我们在第二步已经判断了mid对应的索引值不是我们要的值了。所以缩小空间进行查找时,则不需要加mid这个位置带上了

代码实现

  //二分法查找值的下标
  public static int binarySearchIndex(int[] nums,int val,int start,int end){
        if(end-start<0){
          //找不到对应值,返回-1
            return -1;
        }
        int mid = (start+end+1)/2;
        if(nums[mid]==val){
            //找到对应值,返回对应值下标
            return mid;
        }else if(nums[mid]>val){
            return binarySearchIndex(nums,val,0,mid-1);
        }else{
            return binarySearchIndex(nums,val,mid+1,end);
        }
    }

思考:
能否优化二分查找法,快速获取新数值在原有序数组中的插入位置?

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 先玩一个小游戏。预先给定一个小于100的正整数x,让你猜,猜测过程中给予大小判断的提示,问你怎样快速地猜出来? 这...
    _hider阅读 1,136评论 0 2
  • 一.二分法概述 [一维数组[https://baike.baidu.com/item/%E6%95%B0%E7%B...
    只是甲阅读 312评论 0 0
  • 二分查找(java实现) 二分查找 搜索数据与有序数组中间元素比较以确定在中间元素左边还是右边,如果在右边,则调整...
    李妍_2022公益强化班阅读 253评论 0 1
  • 二分法查找效率高,其查找次数与总元素数量存在对数关系 原理在进行二分法查找前需要先对数据进行排序(具体排序实现详见...
    Spike_Spiegel阅读 449评论 0 0
  • Java 实现二分法查找算法 算法 假如有一组数为3,12,24,36,55,68,75,88要查给定的值24.可...
    康熙微博私访记阅读 4,955评论 0 8