
DsVector의 join() 메소드는 두 개의 DsVector 인스턴스를 하나의 DsVector 인스턴스로 합칩니다. 중복된 데이터가 있는 경우, join() 메소드는 중복된 데이터를 제거하지 않고, 중복된 데이터를 모두 포함하여 합칩니다.
DsVector는 중복된 데이터를 허용하는 자료구조이기 때문에, 중복된 데이터를 제거하는 옵션은 제공되지 않습니다. 만약 중복된 데이터를 제거하고 싶다면, 중복된 데이터를 제거하는 알고리즘을 직접 구현하거나, 다른 자료구조를 사용하는 것이 좋습니다.
예를 들어, 중복된 데이터를 제거하는 알고리즘을 직접 구현할 수 있습니다.
#hostingforum.kr
c
DsVector v1;
DsVector v2;
DsVector result;
// v1과 v2를 join
result = v1.join(v2);
// 중복된 데이터를 제거
DsVector temp;
for (int i = 0; i < result.size(); i++) {
bool found = false;
for (int j = 0; j < temp.size(); j++) {
if (result[i] == temp[j]) {
found = true;
break;
}
}
if (!found) {
temp.append(result[i]);
}
}
// temp를 result에 대입
result.clear();
result = temp;
이 코드는 중복된 데이터를 제거하는 알고리즘을 직접 구현하여, 중복된 데이터를 제거한 결과를 반환합니다.
또한, 다른 자료구조를 사용하는 것도 좋은 방법입니다. 예를 들어, DsSet을 사용할 수 있습니다. DsSet은 중복된 데이터를 허용하지 않기 때문에, 중복된 데이터를 제거하는 문제가 발생하지 않습니다.
#hostingforum.kr
c
DsSet v1;
DsSet v2;
DsSet result;
// v1과 v2를 join
for (int i = 0; i < v1.size(); i++) {
result.insert(v1[i]);
}
for (int i = 0; i < v2.size(); i++) {
result.insert(v2[i]);
}
이 코드는 DsSet을 사용하여, 중복된 데이터를 제거한 결과를 반환합니다.
따라서, 중복된 데이터를 제거하고 싶다면, 중복된 데이터를 제거하는 알고리즘을 직접 구현하거나, 다른 자료구조를 사용하는 것이 좋습니다.
2025-06-09 13:59