0

0

在Java中如何使用Arrays.binarySearch查找元素_二分查找原理与使用解析

P粉602998670

P粉602998670

发布时间:2025-12-03 12:06:06

|

822人浏览过

|

来源于php中文网

原创

Arrays.binarySearch基于二分查找实现,要求数组已排序,否则结果不可预测。其核心原理是通过比较中间元素与目标值,逐步缩小搜索范围,时间复杂度为O(log n)。使用时需调用Arrays.sort()预先排序,支持基本类型和对象数组,对象需实现Comparable或传入Comparator。方法返回目标索引或负插入点-1,如-3表示应插入位置2。示例中查找7返回3,查找4返回-3,指定范围[0,4)查找5返回2。注意未排序数组、浮点数特殊值及重复元素可能导致意外结果。掌握排序前提和返回值含义是正确使用的关键。

在java中如何使用arrays.binarysearch查找元素_二分查找原理与使用解析

在Java中,Arrays.binarySearch 是一个高效查找数组元素的工具,基于二分查找算法实现。它要求被搜索的数组必须是已排序的,否则结果不可预测。下面详细介绍其原理和使用方法。

二分查找的基本原理

二分查找(Binary Search)是一种在有序数组中查找目标值的算法,核心思想是不断缩小搜索范围:

  • 比较中间位置的元素与目标值
  • 如果相等,查找成功,返回索引
  • 如果目标值小于中间元素,则在左半部分继续查找
  • 如果目标值大于中间元素,则在右半部分继续查找
  • 重复上述过程直到找到元素或搜索区间为空

时间复杂度为 O(log n),远优于线性查找的 O(n)。

Arrays.binarySearch 的基本用法

Java 提供了多种重载版本的 binarySearch 方法,适用于不同数据类型和查找范围。常用形式如下:

立即学习Java免费学习笔记(深入)”;

int index = Arrays.binarySearch(array, key);
int index = Arrays.binarySearch(array, fromIndex, toIndex, key);

参数说明:

  • array:要搜索的数组(必须已排序)
  • key:要查找的目标值
  • fromIndex:起始索引(包含)
  • toIndex:结束索引(不包含)

返回值:

唱鸭
唱鸭

音乐创作全流程的AI自动作曲工具,集 AI 辅助作词、AI 自动作曲、编曲、混音于一体

下载
  • 若找到目标值,返回其在数组中的索引
  • 若未找到,返回一个负数,表示“插入点”:-(插入位置) - 1

例如,返回 -3 表示该元素应插入到索引 2 处以保持有序。

实际使用示例

以下代码演示如何正确使用 binarySearch:

import java.util.Arrays;

public class BinarySearchExample { public static void main(String[] args) { int[] nums = {1, 3, 5, 7, 9, 11};

    // 查找存在的元素
    int index1 = Arrays.binarySearch(nums, 7);
    System.out.println("元素 7 的索引:" + index1); // 输出 3

    // 查找不存在的元素
    int index2 = Arrays.binarySearch(nums, 4);
    System.out.println("元素 4 未找到,插入点:" + index2); // 输出 -3

    // 在指定范围内查找
    int index3 = Arrays.binarySearch(nums, 0, 4, 5);
    System.out.println("在 [0,4) 范围内查找 5:" + index3); // 输出 2
}

}

注意事项与常见问题

使用 Arrays.binarySearch 时需注意以下几点:

  • 数组必须提前排序,可使用 Arrays.sort() 排序
  • 对未排序数组调用 binarySearch 结果无意义
  • 对于对象数组,元素需实现 Comparable 接口,或使用带 Comparator 的版本
  • 浮点数数组要注意 NaN 和正负零的影响
  • 重复元素存在时,返回的索引不一定是第一个或最后一个

基本上就这些。只要记住排序前提和返回值含义,Arrays.binarySearch 就能帮你快速定位元素。不复杂但容易忽略细节。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据类型有哪几种
数据类型有哪几种

数据类型有整型、浮点型、字符型、字符串型、布尔型、数组、结构体和枚举等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

308

2023.10.31

php数据类型
php数据类型

本专题整合了php数据类型相关内容,阅读专题下面的文章了解更多详细内容。

222

2025.10.31

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

391

2023.09.04

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1076

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

169

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1336

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

16

2026.01.19

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

407

2023.08.14

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

9

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.9万人学习

C# 教程
C# 教程

共94课时 | 7.7万人学习

Java 教程
Java 教程

共578课时 | 51.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号