배열의 요소들 중에 중복 요소를 찾는 방법을 소개합니다.
1. set를 이용하여 중복 찾기
set
는 기본적으로 중복 요소를 허용하지 않는 자료구조입니다.
아래와 같이 set와 for문을 이용하여 중복 요소를 찾을 수 있습니다. unordered_set.find()
는 인자로 전달된 값이 set에 있을 때 그 값을 iterator로 리턴하며, set에 존재하지 않는다면 unordered_set.end()
를 리턴합니다.
#include <iostream>
#include <unordered_set>
int main() {
int arr[] = {1, 2, 5, 3, 2, 5, 9, 7};
int n = sizeof(arr) / sizeof(*arr);
std::unordered_set<int> seen;
std::unordered_set<int> duplicates;
for (int i = 0; i < n; i++) {
if (seen.find(arr[i]) != seen.end()) {
// found
duplicates.insert(arr[i]);
}
seen.insert(arr[i]);
}
for (const int &i: duplicates) {
std::cout << i << ' ';
}
return 0;
}
Output:
5 2
2. std::count()를 이용하여 중복 찾기
std::count(first, last, val)는 인자로 전달된 배열의 first와 last의 범위의 요소들 중에 val과 같은 값이 몇개가 있는지 개수를 리턴합니다.
아래와 같이 배열에 같은 값의 요소가 2개 이상 있다면 중복 요소가 있다고 볼 수 있습니다. 이렇게 중복 요소를 찾을 수 있습니다.
#include <iostream>
#include <unordered_set>
#include <algorithm>
int main() {
int arr[] = {1, 2, 5, 3, 2, 5, 9, 7};
int n = sizeof(arr) / sizeof(*arr);
std::unordered_set<int> duplicates;
for (int i = 0; i < n; i++) {
int count = std::count(std::begin(arr), std::end(arr), arr[i]);
if (count > 1) {
duplicates.insert(arr[i]);
}
}
for (const int &i: duplicates) {
std::cout << i << ' ';
}
return 0;
}
Output:
5 2
Loading script...
Related Posts
- [C++] 배열을 리스트(list)로 변환
- [C++] 배열에서 특정 요소 제거
- [C++] vector 모든 요소의 합계 계산
- [C++] 두개의 배열이 같은지 비교
- [C++] 배열에 특정 요소가 있는지 확인
- [C++] 2차 배열 복사 방법
- [C++] 배열 복사하는 방법 (copy, memcpy)
- [C++] 함수의 인자로 배열 전달
- [C++] vector 모든 값의 평균 계산
- [C++] vector를 문자열로 변환
- [C++] 배열에서 요소의 Index 찾기
- [C++] 배열의 중복 요소 찾기
- [C++] 배열의 중복 요소 제거
- [C++] 배열 순서 거꾸로 뒤집기
- [C++] char 배열을 string으로 변환
- [C++] string을 char 배열로 변환
- [C++] 문자열 거꾸로 뒤집기
- [C++] vector의 중복 요소 제거
- [C++] 두 배열을 하나의 배열로 합치기
- [C++] 배열 길이, 크기 얻는 방법
- [C++] 배열에서 최대값, 최소값 찾기 (3가지 방법)
- [C++] int를 string으로 변환, 3가지 방법
- [C++] 문자열 리스트(Vector, 배열) 정렬
- [C++] string의 문자 정렬
- [C++] string을 int로 변환, 3가지 방법
- [C++] string 대문자/소문자 변환 방법
- [C++] string.compare() 문자열 비교
- [C++] int를 char로 변환, 3가지 방법
- [C++] 문자열 자르기, 3가지 방법
- [C++] isdigit(), 어떤 문자가 숫자인지 확인
- [C++] strlen(), 문자열 길이 계산
- [C++] strcmp(), strncmp() 함수로 문자열 비교
- [C++] strstr(), 특정 문자열 찾기