二分查找算法

简介: 二分查找算法

二分查找

二分查找又叫折半查找,是一种简单又快速的查找算法;它对要查找的序列有个要求。

  • 前提是该序列是已经排序好的,升序降序都可以
  • 我这里默认为升序

代码实现:

  • 定义一个方法,传入一个数组和需要查询的值,用来查询这个值对应的索引
private static int searchIndex(int[] a, int val) {
        // 开始下标
        int start = 0;
        // 结束下标
        int end = a.length - 1;
        while (start <= end) {
            // 获取中间索引, >>>无符号右移(/2)
            int indexHalf = (start + end) >>> 1;
            if (a[indexHalf] > val) {
                end = indexHalf - 1;
            } else if (a[indexHalf] < val) {
                start = indexHalf + 1;
            } else {
                return indexHalf;
            }
        }
        return -1;
    }
  • 传入参数和需要查询索引的值
public class Test1 {
    public static void main(String[] args) {
        // 定义一个有序数组
        int[] a = {2, 3, 5, 67, 234};
        // 接收67对应的索引
        int index = searchIndex(a, 67);
        System.out.println(index); // 3
    }
}

结果输出3,也就是67在数组的下标为3。

目录
相关文章
|
3月前
|
算法
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
【算法】二分查找——在排序数组中查找元素的第一个和最后一个位置
|
1月前
|
算法 C# 索引
C#二分查找算法
C#二分查找算法
|
1月前
|
存储 算法 C语言
【C语言】二分查找算法
【C语言】二分查找算法
|
1月前
|
消息中间件 存储 算法
一文搞懂二分查找算法!
一文搞懂二分查找算法!
|
1月前
|
算法 Java 索引
数据结构与算法学习十五:常用查找算法介绍,线性排序、二分查找(折半查找)算法、差值查找算法、斐波那契(黄金分割法)查找算法
四种常用的查找算法:顺序查找、二分查找(折半查找)、插值查找和斐波那契查找,并提供了Java语言的实现代码和测试结果。
21 0
|
3月前
|
存储 算法 Java
深入算法基础二分查找数组
文章深入学习了二分查找算法的基础,通过实战例子详细解释了算法的逻辑流程,强调了确定合法搜索边界的重要性,并提供了Java语言的代码实现。
深入算法基础二分查找数组
|
3月前
|
算法
【算法】二分查找——二分查找
【算法】二分查找——二分查找
|
4月前
|
算法
【算法】二分查找(整数二分和浮点数二分)
算法学习——二分查找(整数二分和浮点数二分)
44 0
【算法】二分查找(整数二分和浮点数二分)
|
5月前
|
存储 算法 C语言
二分查找算法的概念、原理、效率以及使用C语言循环和数组的简单实现
二分查找算法的概念、原理、效率以及使用C语言循环和数组的简单实现
|
5月前
|
机器学习/深度学习 算法 索引
数据结构算法--1 顺序查找二分查找
**顺序查找时间复杂度为O(n)**,适合无序列表,可以通过`enumerate`或直接遍历索引来实现。**二分查找时间复杂度为O(logn)**,适用于有序列表,利用Python中`left`、`right`指针和`mid`点不断缩小搜索范围。效率上二分查找更优。
下一篇
无影云桌面