이 기사에서는 C++ STL에서 map equal '[]' 연산자의 작동, 구문 및 예에 대해 설명합니다.
C++ STL의 지도란 무엇입니까?
맵은 키 값과 매핑된 값의 조합으로 형성된 요소를 특정 순서로 저장하는 데 도움이 되는 연관 컨테이너입니다. 지도 컨테이너에서 데이터는 항상 관련 키를 사용하여 내부적으로 정렬됩니다. 지도 컨테이너의 값은 고유 키로 액세스됩니다.
'[]' 연산자와 같은 맵이란 무엇입니까?
map::operator[]는 참조 연산자입니다. 이 연산자는 키로 컨테이너의 요소에 액세스하는 데 사용됩니다.
컨테이너에 일치하는 키가 없으면 연산자는 해당 키가 있는 새 요소를 삽입하고 매핑된 값의 참조를 반환합니다. 이 연산자는 map::at()과 동일하게 작동합니다. 유일한 차이점은 키가 맵 컨테이너에 없을 때 at()에서 예외가 발생한다는 것입니다.
구문
Map_name[key& k];
매개변수
하나의 매개변수, 즉 컨테이너에서 참조하려는 키 k만 있습니다.
반환 값
이 연산자는 키 k와 관련된 값을 반환합니다.
입력 -
map<char, int> newmap; newmap.insert({1, 20}); newmap.insert({2, 30}); newmap[1];
출력
20
예시
#include <bits/stdc++.h> using namespace std; int main(){ map<int, int> TP_1; map<int, int> TP_2; TP_1[1] = 10; TP_1[2] = 20; TP_1[3] = 30; TP_1[4] = 40; cout<<"Element at TP[3] is : "<<TP_1[3]; return 0; }
출력
위의 코드를 실행하면 다음 출력이 생성됩니다 -
Element at TP[3] is : 30
예시
#include <bits/stdc++.h> using namespace std; int main(){ map<int, int> TP_1; map<int, int> TP_2; TP_1[1] = 10; TP_1[2] = 20; TP_1[3] = 30; TP_1[4] = 40; cout<<"Element at TP[3] is : "<<TP_1[3]; if(TP_1[5]==0){ cout<<"\nElement at TP[5] doesn't exist"; } else{ cout<<"Element at TP[5] is : "<<TP_1[5]; } return 0; }
출력
위의 코드를 실행하면 다음 출력이 생성됩니다 -
Element at TP[3] is : 30 Element at TP[5] doesn't exist