Algorithm

[알고리즘] Seach: Binary Search

noahkim_ 2023. 10. 26. 22:48

1. Binary Search 란?

  • 정렬된 배열에서 찾고자 하는 요소를 빨리 찾는 알고리즘 입니다.
  • 주로 Binary Search Tree에서 사용됩니다.

 

과정

중간 원소 선택
범위 지정
  • 찾고자 하는 값보다 작다면, 배열의 오른쪽 반을 대상으로 이진 검색
  • 찾고자 하는 값보다 크다면, 배열의 왼쪽 반을 대상으로 이진 검색

 

찾을때까지 반복 (재귀적)

 

Lower Bound

  • 값이 해인 인덱스 중, 가장 작은 인덱스 값
더보기
while (left < right) {
    long mid = (left+right)/2;

    if (arr[mid] < n) left = mid+1;
    else right = mid;
}

return left;

 

Upper Bound

  • 해를 초과하는 값 중, 가장 작은 값의 가장 작은 인덱스 값
더보기
while (left < right) {
    long mid = (left+right)/2;

    if (arr[mid] <= n) left = mid+1;
    else right = mid;
}

return left;

 

2. 구현

Array

더보기
public int search(int[] arr, int data) {
    int l = 0, r = arr.length-1;

    while (l <= r) {
        int m = (l+r)/2;

        if (arr[m] == data) return data;
        else if (arr[m] > data) r = m-1;
        else l = m+1;
    }

    return -1;
}

 

Binary Search Tree

더보기
public class BinarySearchTree {
    public int search(int data) {
    	return search(this.root, data);
    }
	 
    public Node search(Node node, int data) {
        if (node == null) return null;
        
    	if (node.data == data) return node;
        else if (node.data > data) return search(node.left, data);

        return search(node.right, data);        
    }
}

'Algorithm' 카테고리의 다른 글

[기초 알고리즘] String  (0) 2023.11.08
[기초 알고리즘] 수학: 소수  (0) 2023.11.08
[고급 알고리즘] Greedy  (0) 2023.11.08
[알고리즘] Range: Two Pointer  (0) 2023.11.08
[기초 알고리즘] Sort  (0) 2023.10.26