lower_bound()와 upper_bound() 질문입니다.
해결된 질문
209
작성자 없음
작성한 질문수 0
0
안녕하세요.
p.69의 예제를 보아도 왜 출력값이 저렇게 나오는지 이해가 가지 않아 질문드립니다.
"값이 없다면 근방 지점의 값을~" 이라 하셨는데,
출력값은 그 근방이 아닌듯합니다 ㅠㅠ
감사합니다
답변 1
0
안녕하세요 ㅎㅎ 제가 좀 더 이해가 쉽게 하기 위해 주석을 더 달았는데요.
혹시 이해가 가실까요?
#include <bits/stdc++.h>
using namespace std;
vector<int> v;
int main(){
for(int i = 2; i <= 5; i++)v.push_back(i);
v.push_back(7);
// 2 3 4 5 7
cout << upper_bound(v.begin(), v.end(), 6) - v.begin() << "\n";
// 2 3 4 5 7
// 0 1 2 3 4 에서 근방지점인 4번째 (7보다 6이 더 작으므로)
cout << lower_bound(v.begin(), v.end(), 6) - v.begin() << "\n";
// 2 3 4 5 7
// 0 1 2 3 4 에서 근방지점인 4번째 (7보다 6이 더 작으므로)
cout << upper_bound(v.begin(), v.end(), 9) - v.begin() << "\n";
// 2 3 4 5 7
// 0 1 2 3 4 에서 근방지점인 5번째(7보다 9가 더 크므로)
cout << lower_bound(v.begin(), v.end(), 9) - v.begin() << "\n";
// 2 3 4 5 7
// 0 1 2 3 4 에서 근방지점인 5번째(7보다 9가 더 크므로)
cout << upper_bound(v.begin(), v.end(), 0) - v.begin() << "\n";
// 2 3 4 5 7
// 0 1 2 3 4 에서 근방지점인 0번째(0보다 2가 더 크므로)
cout << lower_bound(v.begin(), v.end(), 0) - v.begin() << "\n";
// 2 3 4 5 7
// 0 1 2 3 4 에서 근방지점인 0번째(0보다 2가 더 크므로)
}
/*
4
4
5
5
0
0
*/
1-E질문입니다!
0
518
2
3-L 틀린 부분 피드백 부탁드립니다.
0
821
2
1-A문제 순열재귀함수 질문입니다.
0
384
1
1-A 일곱난쟁이문제입니다
0
456
1
문제 풀 때 방향성에 대해
0
800
1
맥에서 vs code로 실행 관련 질문입니다
0
523
1
17071번 메모리 초과
0
386
1
1-C질문입니다!
0
421
2
2-B BFS 시간초과질문
0
630
2
1-O 13번 라인
0
442
1
6-J 놀이공원 문제 질문
0
381
1
구현관련 질문
0
484
1
강의 교안
0
319
1
실력을 더 올리고나서 강의를 보는 것이 맞을까요?
0
545
1
안녕하세요! 재귀함수에 관해서 질문드립니다
0
536
1
1-K
0
473
2
3-G번 질문있습니다.
1
473
3
3-C 실행 시간 질문드립니다.
0
493
1
4-A 문제 풀이 질문있습니다.
0
590
2
비트마스킹 연산자 "1의 보수" 영문 표기법
0
435
1
격자탐색 문제에서 BFS 시간복잡도 질문드립니다.
0
334
1
3-O go 함수 질문 드립니다.
1
447
2
4-A 출력 질문
0
305
1
1주차 1-O 질문드립니다
0
259
1





