Laravel  
laravel
文档
数据库
架构
入门
php技术
    
Laravelphp
laravel / php / java / vue / mysql / linux / python / javascript / html / css / c++ / c#

二分查找java

作者:ares丶技术魂   发布日期:2026-05-29   浏览:94

// 二分查找算法的Java实现

public class BinarySearch {
    // 定义一个方法,用于在有序数组中进行二分查找
    public static int binarySearch(int[] array, int target) {
        int left = 0; // 左边界
        int right = array.length - 1; // 右边界

        while (left <= right) {
            int mid = left + (right - left) / 2; // 计算中间位置,防止溢出

            if (array[mid] == target) {
                return mid; // 找到目标值,返回其索引
            } else if (array[mid] < target) {
                left = mid + 1; // 目标值在右半部分
            } else {
                right = mid - 1; // 目标值在左半部分
            }
        }

        return -1; // 如果没有找到目标值,返回-1
    }

    // 测试代码
    public static void main(String[] args) {
        int[] sortedArray = {1, 3, 5, 7, 9, 11, 13, 15};
        int target = 7;
        int result = binarySearch(sortedArray, target);

        if (result != -1) {
            System.out.println("元素 " + target + " 在数组中的索引为: " + result);
        } else {
            System.out.println("元素 " + target + " 不在数组中");
        }
    }
}

解释说明:

  1. 方法定义binarySearch 方法接收一个有序数组 array 和一个目标值 target,返回目标值在数组中的索引。如果目标值不在数组中,则返回 -1
  2. 左右边界leftright 分别表示当前搜索范围的左右边界。
  3. 中间位置计算mid 是当前搜索范围的中间位置,使用 left + (right - left) / 2 避免了直接计算 (left + right) / 2 可能导致的整数溢出问题。
  4. 比较与调整边界
    • 如果 array[mid] == target,则找到了目标值,返回其索引。
    • 如果 array[mid] < target,说明目标值在右半部分,更新 left
    • 如果 array[mid] > target,说明目标值在左半部分,更新 right
  5. 测试代码:在 main 方法中,我们创建了一个有序数组,并调用 binarySearch 方法来查找目标值 7,最后输出结果。

希望这段代码和解释对你有帮助!

上一篇:java byte类型

下一篇:java public private protected

大家都在看

java url decode

java判断是windows还是linux

java连接数据库的代码

java date类型比较大小

java djl

ubuntu 卸载java

es java api

java list 查找

java 解压rar

jsonobject.tojavaobje

Laravel PHP 深圳智简公司。版权所有©2023-2043 LaravelPHP 粤ICP备2021048745号-3

Laravel 中文站