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


版权声明


基本原理

二分查找(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("目标值不存在");
        }
    }
}
相关推荐
平哥努力学习ing1 分钟前
《数据结构》-第八章 排序
数据结构·算法·排序算法
CoovallyAIHub1 分钟前
为AI装上“纠偏”思维链,开源框架Robust-R1显著提升多模态大模型抗退化能力
深度学习·算法·计算机视觉
小棠师姐10 分钟前
随机森林原理与实战:如何解决过拟合问题?
算法·机器学习·随机森林算法·python实战·过拟合解决
范纹杉想快点毕业33 分钟前
欧几里得算法与扩展欧几里得算法,C语言编程实现(零基础全解析)
运维·c语言·单片机·嵌入式硬件·算法
f***241134 分钟前
Bug悬案:技术侦探的破案指南
算法·bug
Swift社区36 分钟前
LeetCode 472 连接词
算法·leetcode·职场和发展
CoovallyAIHub43 分钟前
YOLO-Maste开源:首个MoE加速加速实时检测,推理提速17.8%!
深度学习·算法·计算机视觉
清铎1 小时前
leetcode_day13_普通数组_《绝境求生》
数据结构·算法
hetao17338371 小时前
2026-01-09~12 hetao1733837 的刷题笔记
c++·笔记·算法
过河卒_zh15667661 小时前
情感型AI被“立规矩”,AI陪伴时代进入下半场
人工智能·算法·aigc·生成式人工智能·算法备案