개발바닥곰발바닥
728x90

이진 탐색 Lower Bound, Upper Bound

이진 탐색은 찾는 값이 존재하는지 탐색하여 하나의 값을 찾는 것이라면 lower bound와 upper bound는 이진 탐색에서 살짝 변형시킨 방식으로 중복된 값이나 상한, 하한선을 찾는 경우 등의 다양한 방식으로 활용할 수 있다.
이진탐색 포스팅

Lower Bound

Lower Bound는 타겟보다 같거나 큰 값이 나오는 처음 위치를 찾는다.
[1, 2, 3, 3, 3, 4, 5] 라는 리스트에서 3을 타겟으로 Lower Bound를 찾으면 결과로 나오는 인덱스는 3이 처음 등장하는 2가 된다.

Upper Bound

Upper Bound는 타겟보다 큰 값이 나오는 처음 위치를 찾는다.
위와 같은 [1, 2, 3, 3, 3, 4, 5] 의 리스트에서 3을 타겟으로 Upper Bound를 찾으면 결과로 나오는
인덱스는 3보다 큰 값인 4가 있는 위치인 5가 된다.


Lower Bound

int lowerBound(int target) {
    int low = 0;
    int high = list.size();
    while(low < high) {
        int mid = (low + high) / 2;
        if(target <= list[mid]) {
        // target이 mid와 같은 경우에도 high만 변하므로 lowerBound 된다.
            high = mid;
        } else {
            low = mid + 1;
        }
    }
    return low
}

Upper Bound

    int upperBound(int target) {
    int low = 0;
    int high = list.size();
    while(low < high) {
        int mid = (low + high) / 2;
        if(target < list[mid]) {
            high = mid;
        } else {
            low = mid + 1;
        }
    }
    return low
}
728x90

'알고리즘 > 이론' 카테고리의 다른 글

[자료구조] 힙(Heap), 최대 힙 (C++)  (0) 2021.08.17
BFS (너비 우선 탐색) C++  (0) 2021.08.14
분할 정복(Divide and Conquer)  (0) 2021.08.10
DFS [깊이 우선 탐색] 란?  (0) 2021.07.28
이진(이분) 탐색 (Binary Search)  (0) 2021.06.22
profile

개발바닥곰발바닥

@bestinu

포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!