重温经典算法——二分查找


版权声明


基本原理

二分查找(Binary Search)是一种基于分治策略的高效搜索算法,适用于有序数组,其核心思想是通过重复将搜索区间分成两半:首先取中间元素与目标值比较,若相等则直接返回位置;若目标值小于中间元素,则在左半区间继续搜索;若目标值大于中间元素,则在右半区间继续搜索,直至找到目标值或搜索区间为空(表明目标不存在)。该算法每次比较可将搜索范围缩小一半,时间复杂度为 O(log n),空间复杂度为 O(1),具有查找速度快、性能稳定的优点。

代码实现

java 复制代码
public class BinarySearch {
    /**
     * 二分查找实现
     * @param arr    有序数组(升序)
     * @param target 目标值
     * @return 目标值索引(未找到时返回 -1)
     */
    public static int binarySearch(int[] arr, int target) {
        int left = 0;
        int right = arr.length - 1; // 右闭区间
        
        while (left <= right) { // 终止条件:左边界 <= 右边界
            int mid = left + (right - left) / 2; // 防溢出写法:(left + right) 可能溢出
            if (arr[mid] == target) {
                return mid; // 找到目标
            } else if (arr[mid] < target) {
                left = mid + 1; // 目标在右半部分
            } else {
                right = mid - 1; // 目标在左半部分
            }
        }
        return -1; // 未找到
    }

    public static void main(String[] args) {
        int[] arr = {2, 5, 8, 12, 16, 23, 38, 45, 56};
        int target = 23;
        int result = binarySearch(arr, target);
        
        if (result != -1) {
            System.out.println("目标值 " + target + " 的索引为: " + result);
            // 输出:目标值 23 的索引为: 5
        } else {
            System.out.println("目标值不存在");
        }
    }
}
相关推荐
菜鸡爱玩3 分钟前
线性代数矩阵相乘
线性代数·算法·矩阵
devilnumber4 小时前
Java 递归算法 详解 + 核心要点 + 实战运用 + 避坑指南
java·开发语言·算法
‎ദ്ദിᵔ.˛.ᵔ₎5 小时前
双指针、滑动窗口、前缀和、二分查找 算法
算法
顾北顾6 小时前
多头注意力机制
人工智能·深度学习·算法
H178535090966 小时前
SolidWorks_基于草图的实体特征20_特征错误排查
算法·3d建模·solidworks
hujinyuan201606 小时前
2025年12月中国电子学会青少年机器人技术等级考试试卷(二级) 真题+答案
人工智能·算法·机器人
bIo7lyA8v7 小时前
算法复杂度评估的实验统计方法与可视化的技术8
算法
李老师讲编程7 小时前
中国电子学会图形化2020.12月Scratch三级考级题
算法·scratch·信息学奥赛·图形化编程·scratch素材
退休倒计时8 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript