직관적이지 않은 동작이 있는데, 아래 예제를 통해 파악해보자.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
{ //찾으려는 값이 있는 경우,
//lower_bound는 가장 왼쪽 위치를
//upper_bound는 가장 오른쪽 보다 한칸 오른쪽 위치를 리턴(주의)
int arr[] = { 1,2,3,4,5,5,5,6 };
auto l = lower_bound(arr, arr + 8, 5);
auto r = upper_bound(arr, arr + 8, 5);
printf("l:%d, r:%d, *l:%d, *r:%d\n", l - arr, r - arr, *l, *r);
}
{ //찾으려는 값이 없는 경우,
//lower_bound는 한칸 오른쪽 위치를,
//upper_bound도 마찬가지로 한칸 오른쪽 위치를 리턴(이경우 두 값이 같음)
int arr[] = { 1,2,3,4,6 };
auto l = lower_bound(arr, arr + 5, 5);
auto r = upper_bound(arr, arr + 5, 5);
printf("l:%d, r:%d, *l:%d, *r:%d\n", l - arr, r - arr, *l, *r);
}
|
cs |
출력:
1
2
|
l:4, r:7, *l:5, *r:6
l:4, r:4, *l:6, *r:6
|
cs |
찾으려는 값이 왼쪽에 더 가까워도, 한칸 오른쪽 위치를 리턴함에 주의하자.
1
2
3
4
|
vector<int> v = { 1,5,10,15,20 };
auto l = lower_bound(v.begin(), v.end(), 11);
auto r = upper_bound(v.begin(), v.end(), 11);
printf("l:%d, r:%d, *l:%d, *r:%d\n", l - v.begin(), r - v.begin(), *l, *r);
|
cs |
출력: (15보다는 10에 가까운 11을 찾았음에도, 15의 인덱스 위치를 리턴함에 주의)
1
|
l:3, r:3, *l:15, *r:15
|
cs |
반응형
'Programming' 카테고리의 다른 글
window에서 vscode로 원격 linux에 대한 ssh 개발환경 설정하기 (0) | 2024.07.20 |
---|---|
yaml (0) | 2024.03.02 |
디자인패턴 (0) | 2023.08.17 |
라즈베리파이 초기 세팅 (0) | 2023.01.20 |