작성
·
205
0
if (findit != m.end())
답변 1
1
vector와 다르게 map은 일차적으로 데이터가 나열된 형태가 아니라
균형이진트리 방식으로 데이터를 관리합니다.
데이터를 넣은 순서와는 무관하게, '정렬'을 해서 관리하는 것이죠.
위 코드에서 0, ... 999 사이의 키 값들을 insert하고, 다시 100이라는 키값을 찾고 있는데요.
map.begin()는 제일 처음 데이터를 가리키는 iterator이고,
map.end()는 실제로 존재하지 않는 데이터(map에 포함되지 않음)를 가리키는 iterator입니다.
위 코드에서 0이 아니라 정렬 순서 중간 쯤에 위치한
100을 서칭 했으니 if (findIt != m.begin())도 만족하는 것이고
첫번째 키값인 0을 서칭하고 동일한 if문을 다시 실행해보면 결과가 다를겁니다.
if (findit != m.end())
이 코드는 (맵에 우리가 찾고자 하는 키값이 있다면)이라는 의미인데,
m.end()가 map에 없는 상태를 의미하니,
역으로 findIt != m.end()을 비교하는 행위는
[findIt이라는 iterator가 map에 없는 상태가 아니라면~] 으로 해석할 수 있겠죠.
상세한 답변에 정말 감사드립니다 ~_~
계속 고민하고 보다보니 익숙해져서 납득이 됐습니다.