How to Remove Duplicates in a Vector in C++


How to Remove Duplicates in a Vector in C++ ?

Answer

To remove duplicates from a vector in C++, you can use the std::sort and std::unique algorithms from the Standard Library, or you can use a std::unordered_set to keep only unique elements.



✐ Examples

1 Remove All Duplicates from a Vector Using std::unordered_set

In this example,

  1. We start by including the necessary headers: <vector>, <unordered_set>, and <iostream>.
  2. We create a vector named vec and initialize it with some integer values, including duplicates.
  3. Next, we create an std::unordered_set named set and initialize it with the elements of vec. The unordered_set only keeps unique elements.
  4. We then create a new vector named unique_vec and initialize it with the elements of the set. This ensures that unique_vec contains only unique elements from the original vector.
  5. Finally, we print the new vector to standard output to see the result.

C++ Program

#include &lt;vector&gt;
#include &lt;unordered_set&gt;
#include &lt;iostream&gt;

int main() {
    std::vector&lt;int&gt; vec = {1, 2, 2, 3, 4, 4, 4, 5, 6, 6};
    std::unordered_set&lt;int&gt; set(vec.begin(), vec.end());
    std::vector&lt;int&gt; unique_vec(set.begin(), set.end());
    std::cout &lt;&lt; "Vector after removing all duplicates: ";
    for (const int &val : unique_vec) {
        std::cout &lt;&lt; val &lt;&lt; " ";
    }
    std::cout &lt;&lt; std::endl;
    return 0;
}

Output

Vector after removing all duplicates: 1 2 3 4 5 6

2 Remove Consecutive Duplicates from a Sorted Vector

In this example,

  1. We start by including the necessary headers: <vector>, <algorithm>, and <iostream>.
  2. We create a vector named vec and initialize it with some integer values, including consecutive duplicates.
  3. Next, we use the std::sort algorithm to sort the vector. This step is crucial because std::unique only removes consecutive duplicates, so the vector must be sorted first.
  4. We then use the std::unique algorithm to remove consecutive duplicates. This algorithm returns an iterator pointing to the new logical end of the vector.
  5. We resize the vector to remove the undefined elements left at the end after using std::unique by passing the iterator returned by std::unique to the erase method.
  6. Finally, we print the modified vector to standard output to see the result.

C++ Program

#include &lt;vector&gt;
#include &lt;algorithm&gt;
#include &lt;iostream&gt;

int main() {
    std::vector&lt;int&gt; vec = {1, 2, 2, 3, 4, 4, 4, 5, 6, 6};
    std::sort(vec.begin(), vec.end());
    auto it = std::unique(vec.begin(), vec.end());
    vec.erase(it, vec.end());
    std::cout &lt;&lt; "Vector after removing duplicates: ";
    for (const int &val : vec) {
        std::cout &lt;&lt; val &lt;&lt; " ";
    }
    std::cout &lt;&lt; std::endl;
    return 0;
}

Output

Vector after removing duplicates: 1 2 3 4 5 6

Summary

In this tutorial, we learned How to Remove Duplicates in a Vector in C++ language with well detailed examples.




More C++ Vectors Tutorials

  1. How to create an Empty Vector in C++ ?
  2. How to Initialize a Vector in C++ ?
  3. How to Get Length of a Vector in C++ ?
  4. How to create a Vector of Size N in C++ ?
  5. How to create a Vector of Numbers from 1 to N in C++ ?
  6. How to create a Vector of Integers in C++ ?
  7. How to create a Vector of Strings in C++ ?
  8. How to create a Vector of Empty Vectors in C++ ?
  9. How to Access Items in a Vector in C++ ?
  10. How to get Item in a Vector at a Specific Index in C++ ?
  11. How to get First Item in a Vector in C++ ?
  12. How to get Last Item in a Vector in C++ ?
  13. How to Iterate Over a Vector in C++ ?
  14. How to Iterate Over a Vector with Index in C++ ?
  15. How to Iterate Over a Vector in Reverse Order in C++ ?
  16. How to check if a Vector is Empty in C++ ?
  17. How to check if a Vector is Not Empty in C++ ?
  18. How to get Sub Vector in C++ ?
  19. How to get the Index of Specified Item in a Vector in C++ ?
  20. How to check if a Specific Item is present in the Vector in C++ ?
  21. How to check if a Vector contains all the items of Another Vector in C++ ?
  22. How to count the Number of Occurrences of Specific Item in the Vector in C++ ?
  23. How to find the Item with Maximum Number of Occurrences in a Vector in C++ ?
  24. How to find the Item with Minimum Number of Occurrences in a Vector in C++ ?
  25. How to Sort a Vector in C++ ?
  26. How to Sort a Vector in Ascending Order in C++ ?
  27. How to Sort a Vector in Descending Order in C++ ?
  28. How to create a Two Dimensional Vector in C++ ?
  29. How to Iterate over a Two Dimensional Vector in C++ ?
  30. How to create a Three Dimensional Vector in C++ ?
  31. How to Copy a Vector in C++ ?
  32. How to Split a Vector in C++ ?
  33. How to Join Vectors in C++ ?
  34. How to Append an Item to a Vector in C++ ?
  35. How to Insert an Item at Specific Index in a Vector in C++ ?
  36. How to Append a Vector to another Vector in C++ ?
  37. How to Concatenate Two Vectors in C++ ?
  38. How to check if Two Vectors are Equal in C++ ?
  39. How to check if Two Vectors have Same Items (Regardless of Order) in C++ ?
  40. How to Convert a Vector of Integers to a Vector of Strings in C++ ?
  41. How to Convert a Vector of Strings to a Vector of Integers in C++ ?
  42. How to Convert a Vector of Floats to a Vector of Strings in C++ ?
  43. How to Convert a Vector of Strings to a Vector of Floats in C++ ?
  44. How to Reverse a Vector in C++ ?
  45. How to Shuffle a Vector in C++ ?
  46. How to Slice a Vector in C++ ?
  47. How to get First N Items from a Vector in C++ ?
  48. How to get Last N Items from a Vector in C++ ?
  49. How to Rotate Items in a Vector in C++ ?
  50. How to Filter Items of a Vector based on a Condition in C++ ?
  51. How to Remove Duplicates in a Vector in C++ ?
  52. How to Remove Item at a Specific Index from a Vector in C++ ?
  53. How to Remove Specific Item from a Vector in C++ ?
  54. How to Remove Items from Vector based on a Condition in C++ ?
  55. How to Sort a String Vector in Dictionary Order in C++ ?
  56. How to Concatenate Strings in Vector in C++ ?
  57. How to create a Vector of Vectors in C++ ?