강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

작성자 없음

작성자 정보가 삭제된 글입니다.

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

lower_bound()와 upper_bound() 질문입니다.

해결된 질문

작성

·

204

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 
*/ 

감사합니다.

제가 콘솔 출력값을 벡터 요소의 값으로 헷갈려서 더 이해를 못했던것 같습니다!

작성자 없음

작성자 정보가 삭제된 글입니다.

질문하기