찾다
Javajava지도 시간자바의 BinarySearch()

Java에서 BinarySearch()는 이진 검색 알고리즘을 사용하여 여러 요소 중에서 특정 핵심 요소를 검색하는 데 도움을 주는 메서드입니다. 이 작업을 수행하려면 요소를 오름차순으로 정렬해야 합니다. 정렬되지 않은 경우 Arrays.sort(arr) 메서드를 사용하여 정렬할 수 있습니다. 그렇지 않으면 결과가 정의되지 않은 것으로 간주됩니다.  선형 검색에 비해 이진 검색이 더 빠른 것으로 간주됩니다. 이로 인해 이진 검색의 시간 복잡도는 O(log n)이라고 합니다. 또한, BinarySearch() 메소드는 java.util.Arrays 패키지에서 인스턴스화될 수 있습니다. BinarySearch() 메서드에 대한 자세한 내용은 다음 섹션에서 설명합니다.

구문:

무료 소프트웨어 개발 과정 시작

웹 개발, 프로그래밍 언어, 소프트웨어 테스팅 등

public static int binarySearch(Object[] a, Object key)

여기서, 매개변수 a와 key는 각각 검색해야 할 배열과 검색해야 할 값입니다.

binarySearch() 메서드는 검색한 핵심 요소의 인덱스를 반환합니다. 키 요소를 찾을 수 없는 경우 삽입되었을 키 요소가 있는 삽입 지점이 반환됩니다. 검색의 핵심 요소가 배열의 다른 요소와 비교할 수 없는 경우 ClassCastException이라는 예외가 발생합니다.

Java에서 BinarySearch() 메서드는 어떻게 작동하나요?

이 메소드가 Java에서 어떻게 작동하는지 살펴보겠습니다.

  1. k가 검색해야 할 핵심 요소라고 가정해 보겠습니다. k를 배열의 중간 요소와 비교합니다.
  2. k가 중간 위치에 있는 요소와 일치하는 경우 중간 인덱스를 반환해야 합니다.
  3. 그렇지 않고 k가 중간 위치의 요소보다 높으면 k는 중간 요소의 오른쪽에서만 찾을 수 있습니다.
  4. 그렇지 않으면 중간 요소의 왼쪽에서 찾을 수 있습니다.

Java에서 BinarySearch()를 구현하는 예

다음은 BinarySearch() 메서드에 대한 일부 프로그램의 예입니다.

예시 #1

코드:

import java.util.Arrays;
public class BinarySearchExample
{
public static void main(String[] args)
{
//create a byte array
byte ba[] = {05, 10, 15, 20, 25, 30};
//create a character array
char ca[] = {'a', 'n', 's', 'p', 'v', 'i', 'd'};
//create an integer array
int ia[] = { 10, 20, 15, 22, 35};
//create a double array
double da[] = {10.1 , 15.34 , 22.25, 13.5};
//create a float array
float fa[] = {13.2f, 25.1f , 22.2f , 43.5f };
//sort all the arrays that created above
Arrays.sort(ba);
Arrays.sort(ca);
Arrays.sort(ia);
Arrays.sort(da);
Arrays.sort(fa);
//enter the key elements that has to be searched in the array
byte bKey = 15;
char cKey = 'i';
int iKey = 22;
double dKey = 15.34;
float fKey = 22.2f;
System.out.println("Element "+ bKey + " is found at the position of " + Arrays.binarySearch(ba,bKey) );
System.out.println("Element "+ cKey + " is found at the position of " + Arrays.binarySearch(ca,cKey) );
System.out.println("Element "+ iKey + " is found at the position of " + Arrays.binarySearch(ia,iKey) );
System.out.println("Element "+ dKey + " is found at the position of " + Arrays.binarySearch(da,dKey) );
System.out.println("Element "+ fKey + " is found at the position of " + Arrays.binarySearch(fa,fKey) );
}
}

출력:

자바의 BinarySearch()

위의 program.Sort() 메소드에서 Array를 사용하여 배열을 정렬한 후 문자, 정수, 부동 소수점, 더블, 바이트 등 다양한 유형의 특정 배열이 생성되고, 배열에서 검색해야 할 요소가 선언됩니다. 그런 다음 Arrays.binarySearch() 메서드를 사용하여 검색된 요소의 인덱스를 인쇄합니다.

배열에는 없는 핵심 요소가 주어졌다고 가정해 보겠습니다. 출력은 어떻게 될까요??

그것을 찾기 위해 핵심 요소의 코드를 아래와 같이 변경해 보겠습니다.

바이트 bKey = 15;
char cKey = 'i';
int iKey = 89;
이중 dKey = 15.34;
float fKey = 22.2f;

즉, iKey=89가 배열에 없으면 아래와 같이 출력됩니다.

자바의 BinarySearch()

보시다시피 위치는 -6으로 출력됩니다. 요소를 검색했는데 찾을 수 없는 경우 해당 요소가 있으면 인덱스의 음수 값이 반환되기 때문입니다. 즉, int ia[] = { 10, 20, 15, 22, 35} 는 주어진 배열입니다. 89가 존재한다면 배열은 int ia[] = { 10, 20, 15, 22, 35, 89};

인덱스가 6이었음을 분명히 알 수 있습니다. 원래 배열에는 없기 때문에 해당 특정 인덱스의 음수 값이 위 출력에 반환됩니다.

예시 #2

다음과 같이 재귀를 사용하여 이진 검색을 수행할 수도 있습니다.

코드:

//sample class
class BinarySearchExample{
public static int binarySearch(int a[], int f, int l, int k){
//if last element is greater than or equal to first element
if (l>=f)
{
//find the mid
int m = f + (l - f)/2;
//if the key element that is searching is found in middle position, return mid position
if (a[m] == k)
{
return m;
}
//if key element is less than element in middle position, search the left <u>subarray</u>
if (a[m] > k){
return binarySearch(a, f, m-1, k);
}
//if key element is greater than the element in middle position, search the right <u>subarray</u>
else{
return binarySearch(a, m+1, l, k);
}
}
return -1;
}
public static void main(String args[]){
//initialise the array
int a[] = {34,45,54,68,79};
int k = 68;
int l = a.length-1;
//store the position in variable res
int res = binarySearch(a,0,l,k);
if (res == -1)
System.out.println("Sorry!! Can't find the element....!");
else
System.out.println("Element is found at the position: "+res);
}
}

출력:

자바의 BinarySearch()

위 프로그램에서는 배열이 먼저 생성되고, 알아낼 요소도 선언됩니다. BinarySearch() 메소드를 사용하면 핵심 요소의 위치를 ​​찾을 수 있습니다.  요소를 찾을 수 없다고 가정하면 "죄송합니다. 요소를 찾을 수 없습니다."라는 메시지가 인쇄됩니다.

결론

binarySearch()는 이진 검색 알고리즘을 사용하여 배열에서 사용 가능한 여러 요소 중에서 특정 핵심 요소를 찾는 데 도움이 되는 Java 메서드입니다. 이 방법의 작업 및 예는 이 문서에 자세히 설명되어 있습니다.

추천기사

Java의 BinarySearch()에 대한 안내입니다. 여기에서는 Java에서 BinarySearch() 메서드가 작동하는 방식과 코드 구현 예제에 대해 설명합니다. 또한 다른 추천 도움말을 통해 자세히 알아볼 수도 있습니다.

  1. 자바스크립트 수학 함수
  2. Java의 레이아웃
  3. 자바 컴파일러
  4. Java의 병합 정렬

위 내용은 자바의 BinarySearch()의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
带你搞懂Java结构化数据处理开源库SPL带你搞懂Java结构化数据处理开源库SPLMay 24, 2022 pm 01:34 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于结构化数据处理开源库SPL的相关问题,下面就一起来看一下java下理想的结构化数据处理类库,希望对大家有帮助。

Java集合框架之PriorityQueue优先级队列Java集合框架之PriorityQueue优先级队列Jun 09, 2022 am 11:47 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于PriorityQueue优先级队列的相关知识,Java集合框架中提供了PriorityQueue和PriorityBlockingQueue两种类型的优先级队列,PriorityQueue是线程不安全的,PriorityBlockingQueue是线程安全的,下面一起来看一下,希望对大家有帮助。

完全掌握Java锁(图文解析)完全掌握Java锁(图文解析)Jun 14, 2022 am 11:47 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于java锁的相关问题,包括了独占锁、悲观锁、乐观锁、共享锁等等内容,下面一起来看一下,希望对大家有帮助。

一起聊聊Java多线程之线程安全问题一起聊聊Java多线程之线程安全问题Apr 21, 2022 pm 06:17 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于多线程的相关问题,包括了线程安装、线程加锁与线程不安全的原因、线程安全的标准类等等内容,希望对大家有帮助。

详细解析Java的this和super关键字详细解析Java的this和super关键字Apr 30, 2022 am 09:00 AM

本篇文章给大家带来了关于Java的相关知识,其中主要介绍了关于关键字中this和super的相关问题,以及他们的一些区别,下面一起来看一下,希望对大家有帮助。

Java基础归纳之枚举Java基础归纳之枚举May 26, 2022 am 11:50 AM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于枚举的相关问题,包括了枚举的基本操作、集合类对枚举的支持等等内容,下面一起来看一下,希望对大家有帮助。

java中封装是什么java中封装是什么May 16, 2019 pm 06:08 PM

封装是一种信息隐藏技术,是指一种将抽象性函式接口的实现细节部分包装、隐藏起来的方法;封装可以被认为是一个保护屏障,防止指定类的代码和数据被外部类定义的代码随机访问。封装可以通过关键字private,protected和public实现。

归纳整理JAVA装饰器模式(实例详解)归纳整理JAVA装饰器模式(实例详解)May 05, 2022 pm 06:48 PM

本篇文章给大家带来了关于java的相关知识,其中主要介绍了关于设计模式的相关问题,主要将装饰器模式的相关内容,指在不改变现有对象结构的情况下,动态地给该对象增加一些职责的模式,希望对大家有帮助。

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기