C++
연관 컨테이너(Map)
King94
2019. 11. 10. 17:30
map 특징
- set멤버 함수 특징과 거의 비슷 set보기
- key 와 value로 이루어졌으며 이는 pair객체 형태로 저장
- key는 고유한 값이므로 중복 불가 (value값은 중복 가능)
- 자동 정렬
#include<map>
@ map <int, string> m;
@ m.insert(pair <int, string>(123, "park") ) 삽입을 위해서는 pair객체를 인자로 받아야 한다(key, value값으로 쌍이므로
@ m.insert( {123, "jun"} )
@ m[1]=123 []를 사용해서 원소 넣기 가능
접근 방법
@ map<int,string> ::iterator iter;
cout<<iter->first<< (*iter).second<<endl 원소에 접근하기 위해서 2가지 방법이 존재하다
<C++코드>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
#include<iostream>
#include<map>
using namespace std;
int main(void)
{
map<int,string> m;
m.insert(pair<int,string>(1,"이주연"));
m.insert(pair<int,string>(3,"양배추"));
m.insert({2,"양상추"});
m.insert({4,"박성준"});
map<int,string> ::iterator iter;
for(iter=m.begin();iter!=m.end();iter++)
{
cout<<iter->first<<' '<<(*iter).second<<endl;
}
map<int,int> s;
s[1]=100;
s[3]=300;
s[2]=200;
map<int,int> ::iterator miter;
for(miter=s.begin();miter!=s.end();miter++)
{
cout<<miter->first<<' '<<(*miter).second<<endl;
}
cout<<"s[2]->900변경"<<endl;
s[2]=900;
for(miter=s.begin();miter!=s.end();miter++)
{
cout<<miter->first<<' '<<(*miter).second<<endl;
}
}
|
cs |
<결과 화면>