C++ multiset - cend() Function
The C++ multiset::cend function returns the constant iterator (const_iterator) pointing to the past-the-last element of the multiset container. The past-the-last element of the multiset is the theoretical element that follows the last element. It does not point to any element, and hence could not be dereferenced.
Note: A const_iterator is an iterator that points to constant value. The difference between iterator and const_iterator is that the const_iterator cannot be used to modify the contents it points to, even if the multiset element is not itself constant.
Note: Multiset is an ordered data container which implies all its elements are ordered all the time.
Syntax
const_iterator cend() const noexcept;
Parameters
No parameter is required.
Return Value
A const_iterator to the past-the-last element of the sequence container.
Time Complexity
Constant i.e, Θ(1).
Example:
In the example below, the multiset::cend function returns the const_iterator pointing to the past-the-last element of the multiset MyMSet.
#include <iostream> #include <set> using namespace std; int main (){ multiset<string> MyMSet{"Alpha","Coding","Skills"}; multiset<string>::const_iterator cit; cit = MyMSet.cend(); cit--; cout<<*cit<<" "; cit--; cout<<*cit<<" "; cit--; cout<<*cit<<" "; return 0; }
The output of the above code will be:
Skills Coding Alpha
Example:
Lets see another example where the multiset called MyMSet contains integer values and multiset::cend function is used with multiset::cbegin function to specify a range including all elements of the multiset container. Please note that, Multiset is an ordered data container.
#include <iostream> #include <set> using namespace std; int main (){ multiset<int> MyMSet{55, 25, 128, 5, 72, 55}; multiset<int>::const_iterator cit; for(cit = MyMSet.cbegin(); cit != MyMSet.cend(); ++cit) cout<<*cit<<" "; return 0; }
The output of the above code will be:
5 25 55 55 72 128
❮ C++ <set> Library