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


版权声明


基本原理

二分查找(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("目标值不存在");
        }
    }
}
相关推荐
拼好饭和她皆失几秒前
基础算法--写给算法小白的模板指南:快速掌握核心代码,蓝桥杯必备模板
算法
吞下星星的少年·-·几秒前
rotate函数应用模板
算法
AI科技星4 分钟前
人类首张【全域数学公理体系】黑洞内部结构图—基于「0-1-∞」三元本源的全维深度解析
人工智能·算法·机器学习·数学建模·数据挖掘·量子计算
paeamecium19 分钟前
【PAT甲级真题】- Recover the Smallest Number (30)
数据结构·算法·pat考试·pat
Dillon Dong22 分钟前
【风电控制】变流器转矩控制回路深度解析:从指令生成到闭环控制
算法·变流器·风电控制
玛丽莲茼蒿27 分钟前
Leetcode hot100 在排序数组中查找元素的第一个和最后一个位置【中等】
数据结构·算法
墨染天姬32 分钟前
[AI]OPENAI的PPO算法
人工智能·算法
cici158741 小时前
含风光储燃的微电网能量管理系统(PSO优化)
算法
Das11 小时前
图像色彩迁移技术算法及基本原理
算法
发疯幼稚鬼1 小时前
二叉树的广度优先遍历
c语言·数据结构·算法·宽度优先