二分查找(折半查找)

  • 这次不排序了,对排好序的数组做个查找吧

介绍

  • 二分查找排序英文名为BinarySort,是一种效率较高的查找方法
  • 要求线性表必须采用顺序存储结构

基本思路

  • 通过不断地将搜索范围缩小一半来找到目标元素:
    • 1、假定数组为arr,需要查找的值为target
    • 2、定义left、right 和mid三个索引。mid=(left+right)/2;
    • 3、如果中间元素正好是要查找的元素,搜索结束;
      ( 即arr[mid]==target,结束)
    • 4、如果目标元素大于中间元素,那么在数组的右半部分继续查找
      ( 即arr[mid]>target,循环或者递归右半部分)
    • 5、如果目标元素小于中间元素,那么在数组的左半部分继续查找
      ( 即arr[mid]<target,循环或者递归左半部分)
    • 6、重复以上步骤,直到找到目标元素或者搜索范围为空(找不到目标值)

代码

  • 循环方法

    public static void main(String[] args) {
        int[] arr = {1,10, 20, 30, 40, 50, 60, 70, 80, 90};
        sort(arr,60);
        sort(arr,45);
        sort(arr,1);
    }
    
    public static int sort(int[] arr,int target){
        int left = 0;
        int right = arr.length-1;
    
        while(left<=right){ // 此处=是为了当索引移动后只剩一个时,也需要比较
            int mid = (left+right)/2; // 放在while循环外边就成了固定值了
            if(arr[mid]==target){
                System.out.println("找到了!");
                return mid;
            }else if(arr[mid]<target){ // 目标值比中间值大,要往右边查找
                left = mid+1;
            }else{    // 目标值比中间值小,要往左边查找
                right = mid-1;
            }
        }
        System.out.println("没有该数值");
        return -1;
    }
    ------------输出结果--------------
    找到了【60】,位置是:6
    数值【45】不存在
    找到了【1】,位置是:0
    
  • 递归方法

    public static void main(String[] args) {
        int[] arr = {1,10, 20, 30, 40, 50, 60, 70, 80, 90};
        digui(arr,60,0,arr.length-1);
        digui(arr,45,0,arr.length-1);
        digui(arr,1,0,arr.length-1);
    }
    public static int digui(int[] arr,int target,int left,int right){
        if(left>right){
            System.out.println("不存在该数值");
            return -1;
        }
        int mid = (left+right)/2;
        if(arr[mid]==target){
            System.out.println("找到了!");
            return mid;
        }else if(arr[mid]>target){ // 目标值比中间值小
            return digui(arr,target,left,mid-1);
        }else{
            return digui(arr,target,mid+1,right);
        }
    }
    ------------输出结果--------------
    找到了【60】,位置是:6
    数值【45】不存在
    找到了【1】,位置是:0
    

老规矩,来个流程图

  • 希望这三张图能帮忙大家理解为什么left<=right
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

时间复杂度

  • 最好情况是O(1),即一下就找到了
  • 平均是O(logN)

相关推荐

  1. 查找——顺序查找折半查找

    2024-07-17 19:54:02       30 阅读
  2. 二分查找.

    2024-07-17 19:54:02       26 阅读
  3. leetcode704. 二分查找

    2024-07-17 19:54:02       54 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-17 19:54:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-17 19:54:02       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-17 19:54:02       58 阅读
  4. Python语言-面向对象

    2024-07-17 19:54:02       69 阅读

热门阅读

  1. XML详解

    2024-07-17 19:54:02       18 阅读
  2. Vue进阶之Vue无代码可视化项目(六)

    2024-07-17 19:54:02       19 阅读
  3. 209.长度最小的子数组 数组 双指针 滑动窗口

    2024-07-17 19:54:02       19 阅读
  4. notes for datawhale 2th summer camp NLP task2

    2024-07-17 19:54:02       21 阅读
  5. linux学习笔记整理: 关于linux系统介绍 2024/7/16;

    2024-07-17 19:54:02       21 阅读
  6. 单例模式-C#

    2024-07-17 19:54:02       18 阅读
  7. 常用的系统层安全机制

    2024-07-17 19:54:02       21 阅读
  8. 什么是智能家居?

    2024-07-17 19:54:02       19 阅读
  9. C++的关键字const

    2024-07-17 19:54:02       21 阅读
  10. 服务端正常启动了,但是客户端请求不到

    2024-07-17 19:54:02       22 阅读