상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - C++에서 집합(set) 자료구조의 사용법은?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
C++에서 집합(set) 자료구조는 STL(Standard Template Library)의 일부로 제공되며, 중복되지 않는 요소들을 저장하고 관리하는 데 유용합니다. 집합은 자동으로 정렬되며, 요소의 삽입, 삭제, 검색이 평균적으로 O(log n)의 시간 복잡도로 수행됩니다. 이 글에서는 C++에서 집합을 사용하는 방법에 대해 자세히 설명하겠습니다. 1. 집합(set) 기본 개념 C++의 `std::set`은 다음과 같은 특징을 가지고 있습니다: - 중복 요소 없음 : 집합은 동일한 값을 여러 번 저장할 수 없습니다. - 자동 정렬 : 요소는 항상 정렬된 상태로 유지됩니다. 기본적으로 오름차순으로 정렬되지만, 사용자 정의 <a href='https://sangseek.com/sangseeks/정렬 기준/ko'>정렬 기준</a>을 제공할 수도 있습니다. - 빠른 검색 : 요소의 존재 여부를 확인하는 것이 빠릅니다. 2. 헤더 파일 포함 집합을 사용하기 위해서는 `<set>` 헤더 파일을 포함해야 합니다. ```cpp include <set> ``` 3. 집합 생성 집합을 생성하는 방법은 다음과 같습니다: ```cpp std::set<int> mySet; // 정수형 집합 생성 ``` 4. 요소 삽입 요소를 집합에 삽입할 때는 `insert()` 메서드를 사용합니다. 중복된 요소를 삽입하려고 하면 무시됩니다. ```cpp mySet.insert(10); mySet.insert(20); mySet.insert(10); // 중복된 요소는 무시됨 ``` 5. 요소 삭제 요소를 삭제할 때는 `<a href='https://sangseek.com/sangseeks/erase/ko'>erase</a>()` 메서드를 사용합니다. 삭제할 요소가 존재하지 않더라도 오류가 발생하지 않습니다. ```cpp mySet.erase(20); // 20을 삭제 ``` 6. 요소 검색 특정 요소가 집합에 존재하는지 확인하려면 `find()` 메서드를 사용할 수 있습니다. 이 메서드는 요소를 찾으면 해당 요소의 반복자를 반환하고, 찾지 못하면 `end()` 반복자를 반환합니다. ```cpp if (mySet.find(10) != mySet.end()) { std::cout << "10이 집합에 존재합니다." << std::endl; } else { std::cout << "10이 집합에 존재하지 않습니다." << std::endl; } ``` 7. 집합의 크기 집합의 크기를 확인하려면 `size()` 메서드를 사용합니다. ```cpp std::cout << "집합의 크기: " << mySet.size() << std::endl; ``` 8. 집합의 <a href='https://sangseek.com/sangseeks/순회/ko'>순회</a> 집합의 모든 요소를 순회하려면 반복자를 사용할 수 있습니다. `begin()`과 `end()` 메서드를 사용하여 반복자를 얻을 수 있습니다. ```cpp for (auto it = mySet.begin(); it != mySet.end(); ++it) { std::cout << *it << " "; } std::cout << std::endl; ``` 9. 사용자 정의 타입의 집합 사용자 정의 타입을 집합에 저장하려면, 해당 타입에 대한 <a href='https://sangseek.com/sangseeks/비교 연산자/ko'>비교 연산자</a>를 정의해야 합니다. 예를 들어, 다음과 같이 구조체를 정의하고 비교 연산자를 오버로딩할 수 있습니다. ```cpp struct Person { std::string name; int age; bool operator<(const Person& other) const { return name < other.name; // 이름을 기준으로 정렬 } }; std::set<Person> people; people.insert({"Alice", 30}); people.insert({"Bob", 25}); ``` 10. 집합의 기타 기능 - 합집합, <a href='https://sangseek.com/sangseeks/교집합/ko'>교집합</a>, 차집합 : `std::set`은 다른 집합과의 연산을 지원하지 않지만, `std::set_union`, `std::set_inter<a href='https://sangseek.com/sangseeks/section/ko'>section</a>`, `std::set_difference`와 같은 알고리즘을 사용하여 이러한 연산을 수행할 수 있습니다. - 정렬 기준 변경 : 집합을 생성할 때 사용자 정의 비교 함수를 제공하여 정렬 기준을 변경할 수 있습니다. ```cpp struct CustomCompare { bool operator()(const int& a, const int& b) const { return a > b; // 내림차순 정렬 } }; std::set<int, CustomCompare> myCustomSet; ``` 결론 C++의 `std::set`은 중복되지 않는 요소를 저장하고 관리하는 데 매우 유용한 자료구조입니다. 자동 정렬, 빠른 검색, 다양한 기능을 제공하여 다양한 상황에서 활용할 수 있습니다. 위에서 설명한 내용을 바탕으로 집합을 효과적으로 사용할 수 있을 것입니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기