질문있습니다!
마지막에 cout을 할때
mp.find를 하려니 에러가 발생해서 막혔었습니다. 강의를 보니 []로 뽑아서 하시던데
find를 사용할때와 []를 사용할때를 어떻게 구분해야할지 감이 잘 잡히지 않습니다!
답변 2
0
안녕하세요, 인프런 AI 인턴입니다. ghtndl님!
C++ STL의 map 컨테이너에서 find와 [] 연산자를 사용하는 방법, 그리고 각각의 구분점에 대해 간단히 설명드리겠습니다.
find함수:find는 특정 키에 대한 반복자를 반환합니다. 만약 키가 존재하지 않는다면end()반복자를 반환합니다.
- 데이터가 존재하는지 확인할 때 사용합니다.
mp.find(key) != mp.end()를 사용하여 키가 존재하는지 체크할 수 있습니다.
- 주로 데이터가 있는지 여부만 확인하고 싶을 때 적합합니다.
[]연산자:- 특정 키에 대한 값을 반환하며, 해당 키가
map에 존재하지 않는 경우 새로운 키-값 쌍을 생성합니다. 생성된 값은 타입의 기본값(default value)이 됩니다 (예: 정수형이라면 0).
- 키에 따라 값을 삽입하거나 업데이트하고 싶을 때 사용합니다.
mp[key]는 기본값 초기화를 유발하기 때문에, 존재 여부 확인 없이 값을 바로 수정 또는 할당할 수 있습니다.
- 특정 키에 대한 값을 반환하며, 해당 키가
따라서, 만약 map에 특정 키의 존재 여부를 확인하고 싶다면 find를 사용하는 것이 좋고, 반면에 값을 초기화하거나 수정하려면 [] 연산자를 사용하는 것을 추천드립니다.
아래 게시물도 참고하시면 더 도움이 될 것 같습니다.
- 강의교재 p106 질문
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
1-O 코딩살구클럽 채점관련 질문
0
5
1
히든 테스트 케이스가 사라졌습니다
0
9
0
채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요
1
23
0
살구 클럽 채점 관련 문의(테스트 케이스)
0
25
1
1-H 문제 채점하기 오류
0
18
2
코딩살구클럽 2주차 2-L 문제 채점하기 오류
0
24
2
살구 클럽 채점 관련 문의
0
31
2
코딩 살구 클럽 실전 세션
0
25
2
코딩살구클럽 채점 관련 질문
0
33
2
코딩살구클럽 컴파일에러
0
62
2
5-B
0
46
2
4 - A
0
47
2
코딩살구클럽 입장이 안됩니다
0
107
2
4-F 경우의 수 질문입니다.
0
46
2
코딩살구클럽 가입이 안됩니다.
0
104
2
살구 클럽에 대한 질문있습ㄴ디ㅏ
0
73
1
교안 158페이지 문의드립니다
0
53
2
코딩살구클럽 관련 건의사항
0
147
1
코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다
0
54
1
진행 방법 질문드립니다!
0
98
2
2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.
0
65
2
2주차 개념#12 트리 순회
0
34
2
백준사이트가 종료된다고 합니다.
0
330
2
백준 서비스 종료
9
999
1






