| (1) | (since C++11) | ||
| (2) | (since C++11) |
Removes all consecutive duplicate elements from the container. Only the first element in each group of equal elements is left. The first version uses operator==
to compare the elements, the second version uses the given binary predicate p
.
Parameters
p | - | binary predicate which returns true if the elements should be treated as equal. The signature of the predicate function should be equivalent to the following:
The signature does not need to have |
Return value
(none).
Complexity
Linear in the size of the container.
Example
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | #include <iostream> #include <forward_list> int main() { std::forward_list< int > x = {1, 2, 2, 3, 3, 2, 1, 1, 2}; std::cout << "contents before:" ; for (auto val : x) std::cout << ' ' << val; std::cout << '\n' ; x.unique(); std::cout << "contents after unique():" ; for (auto val : x) std::cout << ' ' << val; std::cout << '\n' ; return 0; } |
Output:
1 2 | contents before: 1 2 2 3 3 2 1 1 2 contents after unique(): 1 2 3 2 1 2 |
See also
removes consecutive duplicate elements in a range (function template) |
Please login to continue.