티스토리 뷰
Set이란??
set은 key라고 불리는 원소들의 집합으로
이루어진 컨테이너입니다. set안에 들어가는 key값들은 중복될 수 없으며 자동으로 정렬이 됩니다.
set의 구조는 이진균형트리구조를 이루기 때문에 원소의 삽입, 삭제, 검색의 시간복잡도가 O(logN)이 듭니다.
마지막으로 메모리는 동적할당이 됩니다.
Set의 사용법?
가장 먼저 set이라는 헤더파일을 불러와야 합니다.
set변수를 선언할 때는 set<data type>변수
=> set<int>s
Set의 멤버함수
s.begin() => 첫 번째 원소의 반복자를 반환합니다.
s.end() => 마지막 원소의 다음 반복자를 반환합니다.
s.empty() => set이 비어있으면 true를, 비어있지 않으면 false를 반환합니다.
s.clear() => set의 모든 원소들을 삭제합니다.
s.find(a) => k와 관련된 원소의 반복자를 반환하며 원소가 없을 시에는 end()와 같은 결과를 반환합니다.
s.erase(iter) => 반복자가 가리키는 원소를 삭제합니다.
s.erase(key) => 해당되는 key를 삭제합니다.
s.erase(start,end) => start부터 end까지의 원소들을 삭제합니다.
s.size() => set의 원소 개수를 반환합니다.
s.rbegin() => 역방향으로 첫 번째 원소의 반복자를 반환합니다.
s.rend() => 역방향으로 마지막 원소의 다음 반복자를 반환합니다.
s.lower_bound(a) => 원소 k가 시작되는 구간의 반복자 입니다.
s.upper_bound(a) => 원소 a가 끝나는 구간의 반복자 입니다.
s.insert(k) => k를 set에 삽입합니다.
s.insert(iter,k) => iter가 가리키는 위치부터 k를 삽입할 위치를 탐색하여 삽입합니다.
s.count(k) => k의 개수를 반환합니다. set의 특성상 리턴값은 0아니면 1입니다.
기타
중복된 원소를 사용하고 싶으면 multiset을 사용할 수 있습니다.
오름차순이 아니라 내림차순으로 정렬하고 싶으시면 greater를 사용할 수 있습니다.
정렬을 하고 싶지 않으시면 unordered_map이라는 헤더파일을 불러와서 사용할 수 있습니다.
set은 인덱스형식으로 원소를 삽입할 수 없으며 key값으로만 되어있기 때문에 출력하기 위해서는 iterator를
사용하셔야 합니다.
'PL > C++' 카테고리의 다른 글
[자료구조 C/C++] #05. Stack (0) | 2023.07.22 |
---|---|
[자료구조 C/C++] #04. Queue (0) | 2023.07.21 |
[자료구조 C/C++] #2 String (0) | 2023.07.16 |
[자료구조 C/C++] #2 Vector (0) | 2023.07.16 |
[자료구조 C/C++] #1 C++이란? (0) | 2023.07.16 |
- Total
- Today
- Yesterday
- 투 포인터
- 스프링 부트 crud 게시판 구현
- 스택
- java
- DP
- C++ Stack
- BFS
- 자료구조
- 백준
- 자바스크립트
- 세그먼트 트리
- js
- html
- 알고리즘 공부
- C++
- 알고리즘
- 에라토스테네스의 체
- c++ string
- 카운팅 정렬
- 백준 풀이
- DFS
- CSS
- Do it!
- 유니온 파인드
- 이분 매칭
- HTML5
- 우선순위 큐
- 반복문
- 자바
- 유클리드 호제법
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |