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에서 어떻게 작동하는지 살펴보겠습니다.
- k가 검색해야 할 핵심 요소라고 가정해 보겠습니다. k를 배열의 중간 요소와 비교합니다.
- k가 중간 위치에 있는 요소와 일치하는 경우 중간 인덱스를 반환해야 합니다.
- 그렇지 않고 k가 중간 위치의 요소보다 높으면 k는 중간 요소의 오른쪽에서만 찾을 수 있습니다.
- 그렇지 않으면 중간 요소의 왼쪽에서 찾을 수 있습니다.
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) ); } }
출력:
위의 program.Sort() 메소드에서 Array를 사용하여 배열을 정렬한 후 문자, 정수, 부동 소수점, 더블, 바이트 등 다양한 유형의 특정 배열이 생성되고, 배열에서 검색해야 할 요소가 선언됩니다. 그런 다음 Arrays.binarySearch() 메서드를 사용하여 검색된 요소의 인덱스를 인쇄합니다.
배열에는 없는 핵심 요소가 주어졌다고 가정해 보겠습니다. 출력은 어떻게 될까요??
그것을 찾기 위해 핵심 요소의 코드를 아래와 같이 변경해 보겠습니다.
바이트 bKey = 15;
char cKey = 'i';
int iKey = 89;
이중 dKey = 15.34;
float fKey = 22.2f;
즉, iKey=89가 배열에 없으면 아래와 같이 출력됩니다.
보시다시피 위치는 -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()는 이진 검색 알고리즘을 사용하여 배열에서 사용 가능한 여러 요소 중에서 특정 핵심 요소를 찾는 데 도움이 되는 Java 메서드입니다. 이 방법의 작업 및 예는 이 문서에 자세히 설명되어 있습니다.
추천기사
Java의 BinarySearch()에 대한 안내입니다. 여기에서는 Java에서 BinarySearch() 메서드가 작동하는 방식과 코드 구현 예제에 대해 설명합니다. 또한 다른 추천 도움말을 통해 자세히 알아볼 수도 있습니다.
- 자바스크립트 수학 함수
- Java의 레이아웃
- 자바 컴파일러
- Java의 병합 정렬
위 내용은 자바의 BinarySearch()의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

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

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

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

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

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

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

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


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

드림위버 CS6
시각적 웹 개발 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

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

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

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기
