[C++] stl map

2021. 5. 31. 15:41·Data Structure
map에 대한 설명

- 노드기반으로 이루어진 균형 이진 트리 ( 어느 한 곳을 기준으로 왼쪽은 작은 것이, 오른쪽은 큰 것이 저장 )

- key와 value로 이루어져 있으며 pair의 형태로 저장된다

- key는 중복이 되지 않는다 (multimap에서는 중복을 허용한다)

- 삽입, 삭제, 탐색의 시간 복잡도는 O(logN)이다

 

map의 사용 방법
#include <map>

map<string, int> m;	//선언

m.insert(pair<string, int>("hello", 33));	//삽입
m["hello"] = 33;	//이런식으로 삽입도 가능

 

map의 순회방법
map<int, string>::iterator iter;

//방법1
for(iter = m.begin(); iter != m.end(); iter++)
{
	cout << iter->first << ", " << iter->second << " " ;
}

//방법2
for (auto a : m)
{
	cout << a.first << ", " << a.second << " ";
}

 

map의 함수들
m.empty( );		//맵이 비어있는지 확인하는 함수
m.size( );		//맵의 크기를 확인하는 함수
m.find(key);		//맵에서 key에 해당하는 원소를 찾는 함수
m.count(key);		//맵에서 key에 해당하는 원소의 갯수를 반환하는 함수
m.insert({key, value});	//맵에 pair<key,value> 를 추가하는 함수
m.erase(key);		//맵에서 key에 해당하는 원소를 제거하는 함수
m.clear( );		//맵을 초기화하는 함수

 

 

 

참고사이트 : https://blockdmask.tistory.com/87

 

[C++] map container 정리 및 사용법

안녕하세요. BlockDMask 입니다. 오늘은 연관 컨테이너 set, multiset, map, multimap 중. key와 value가 쌍으로 저장되는 map에 대해서 알아보도록 하겠습니다. std::map은 std::vector 처럼 정말 많이 쓰이는 컨..

blockdmask.tistory.com

 

저작자표시 (새창열림)

'Data Structure' 카테고리의 다른 글

레드블랙트리  (0) 2021.08.09
[C++] stl priority_queue와 heap  (0) 2021.06.03
해시(hash)  (0) 2021.01.20
링크드 리스트(Linked List)  (0) 2021.01.19
스택(stack)  (0) 2021.01.15
'Data Structure' 카테고리의 다른 글
  • 레드블랙트리
  • [C++] stl priority_queue와 heap
  • 해시(hash)
  • 링크드 리스트(Linked List)
chanheess
chanheess
'왜' 그렇게 했는가?에 대한 생각으로 공부 및 작업의 저장관리
  • chanheess
    왜 그렇게 생각했는가?
    chanheess
  • 전체
    오늘
    어제
    • 분류 전체보기
      • Backend Programming
      • Game Programming
        • Unreal
        • DirectX
      • C++
        • Memo
        • Basic
        • Effective Modern
      • Java
      • Algorithm
        • Memo
        • Baekjoon
        • Programmers
        • HackerRank, LeetCode
      • Data Structure
      • Design Pattern
      • Etc
        • Memo
        • Daily Log
        • Book
  • 최근 글

  • 최근 댓글

  • 태그

    JWT
    위클리 챌린지
    티스토리챌린지
    c++ 기초 플러스
    dp
    Java
    JPA
    dfs
    백준
    프로그래머스
    오블완
    spring
    SpringSecurity
    알고리즘
  • hELLO· Designed By정상우.v4.10.0
chanheess
[C++] stl map

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.