안녕하세요. BlockDMask 입니다 !
오늘은 연관 컨테이너 set, multiset, map, multimap 중 set에 대해 학습해보겠습니다.
순서는 set container -> set의 사용법 -> set의 생성자와 연산자 -> set의 멤버 함수 -> 다양한 듯 다양하지 않은 예제 순으로 정리 해보겠습니다.
우선 연관컨테이너들의 공통적인 특징은 아래와 같습니다.
1. 노드 기반 컨테이너
2. 균형 이진트리로 구현
3. 멤버 변수, 생성자 등이 99프로 같습니다.
1) set container
- 연관 컨테이너(associative container) 중 하나입니다.
- 노드 기반 컨테이너 이며 균형 이진트리로 구현되어있습니다.
- Key라 불리는 원소들의 집합으로 이루어진 컨테이너 입니다. (원소 = key)
- key값은 중복이 허용 되지않습니다.
- 원소가 insert 멤버 함수에 의해 삽입이 되면, 원소는 자동으로 정렬 됩니다.
- default 정렬기준은 less(오름차순) 입니다.
- 그림으로 보겠습니다.
- 그림에서 보면 알듯이 inorder traversal (중위순회) 를 통하여 순서대로 출력이 가능합니다.
(iterator는 자동으로 inorder traversal 순서대로 출력해줍니다.)
2) set의 사용법
- <set> 헤더 파일에 들어있습니다.
- using namespace std; 를 선언해주면 편리합니다.
- 기본 선언 방법은 : set< [Data Type] > [변수 이름]; 입니다.
ex1) set<int> s;
ex2) set<pair<int, string> > s;
3) set의 생성자와 연산자
- set<int> s;
- 기본 선언 방법. - set<int> s(pred);
- pred를 통해 정렬기준을 세웁니다. - set<int> s2(s1);
- s1 을 복사한 s2
- 연산자 ( "==", "!=", "<", ">", "<=", ">=" ) 사용 가능합니다.
4) set의 멤버 함수
- set<int> s; 기준으로 작성하겠습니다.
- set<int>::iterator iter, start, end; 로 반복자 세개 선언하겠습니다.
- int k 는 원소입니다.
- s.begin();
- 맨 첫번째 원소를 가리키는 반복자를 리턴(참조)합니다.
- iter = s.begin(); 으로 사용합니다.
- s.end();
- 맨 마지막 원소(의 다음)를 가리키는 원소의 끝부분을 알 때 사용합니다.
- 반복자를 리턴(참조)합니다.
- iter = s.end(); - s.rbegin();
s.rend();
- begin(), end() 와 반대로 작동하는 멤버함수들입니다.
- 역으로 출력하고 싶을때 사용합니다.
- 이런 식으로 사용합니다.123for(iter = s.rbegin(); iter != s.rend(); iter++){cout << * iter << endl;}cs - s.clear();
- 모든 원소를 제거합니다. - s.count(k);
- 원소 k 의 갯수를 반환합니다
- set에서는 무조건 0,1 개 겠죠 ? -> multiset은 키값이 중복이 가능하기때문에 거기서 쓰입니다. - s.empty();
- set s가 비어있는지 확인합니다.
- s.insert(k);
- 원소 k를 삽입합니다.
- 삽입시에 자동으로 정렬된 위치에 삽입됩니다.
- 삽입이 성공 실패에 대한 여부는 리턴값 (pair<iterator, bool>) 으로 나오게됩니다.
- pair<iterator, bool>에서 pair.first는 삽입한 원소를 가리키는 반복자 이고, pair.second는 성공(true), 실패(false)를 나타냅니다. - s.insert(iter, k);
- iter가 가리키는 위치 부터 k를 삽입할 위치를 탐색하여 삽입합니다.
- s.erase(iter);
- iter가 가리키는 원소를 제거합니다.
- 제거 한다음 제거 한 원소 다음 원소를 가리키는 반복자를 리턴합니다. - s.erase(start, end);
- [start, end) 범위의 원소를 모두 제거합니다. - s.find(k);
- 원소 k를 가리키는 반복자를 반환합니다.
- 원소 k가 없다면 s.end() 와 같은 반복자를 반환합니다.
- s2.swap(s1);
- s1과 s2를 바꿔줍니다. - s.upper_bound(k);
- 원소 k가 끝나는 구간의 반복자 입니다. - s.lower_bound(k);
- 원소 k가 시작하는 구간의 반복자 입니다.
- s.equal_range(k);
- 원소 k가 시작하는 구간과 끝나는 구간의 반복자 pair 객체를 반환합니다.
- upper_bound(k), lower_bound(k) 가 합쳐진 멤버함수
- s.value_comp();
- s.key_comp();
- 정렬 기준 조건자를 반환합니다.
- set 컨테이너에서는 두개의 함수 반환형이 같습니다.
- s.size();
- 사이즈(원소의 갯수)를 반환합니다. - s.max_size();
- 최대 사이즈(남은 메모리 크기)를 반환합니다.
5) 다양한 듯 다양하지 않은 예제
test) insert, insert(중복값), find(존재하는 값), find(존재하지 않는 값)
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 36 37 38 39 40 41 42 43 44 45 46 47 48 49 | #include<iostream> #include<set> using namespace std; int main(void){ set<int> s; s.insert(40); s.insert(10); s.insert(80); s.insert(30); s.insert(70); s.insert(60); s.insert(20); s.insert(50); set<int>::iterator iter; for(iter = s.begin(); iter != s.end(); iter++){ cout << *iter << " " ; } cout << endl; //중복 값 넣어보기. s.insert(20); for(iter = s.begin(); iter != s.end(); iter++){ cout << *iter << " " ; } cout << endl; //존재 하는 원소 찾기 iter = s.find(30); if(iter != s.end()){ cout << *iter << " : 존재 " << endl; }else{ cout << "존재하지 않음 " << endl; } //존재 하지 않는 원소 찾기 iter = s.find(333); if(iter != s.end()){ cout << *iter << " : 존재 " << endl; }else{ cout << "존재하지 않음 " << endl; } return 0; } | cs |
- 결과
<참고>
http://www.cplusplus.com/reference/set/set/
https://en.wikipedia.org/wiki/Associative_containers
'<개인공부> > [C++]' 카테고리의 다른 글
[C++] stack container 정리 및 사용법 (0) | 2017.08.02 |
---|---|
[C++] multimap container 정리 및 사용법 (2) | 2017.07.29 |
[C++] map container 정리 및 사용법 (10) | 2017.07.28 |
[C++] multiset container 정리 및 사용법 (0) | 2017.07.27 |
[C++] list container 정리 및 사용법 (4) | 2017.07.25 |
[C++] deque container 정리 및 사용법 (2) | 2017.07.23 |
[C++] vector container 정리 및 사용법 (41) | 2017.07.20 |
[C++] STL 이란. (0) | 2017.07.19 |