From cppreference.com
				
				
				
				
																
				
				
								
				
|  | 
| template< class BidirectionalIterator >void reverse( BidirectionalIterator first, BidirectionalIterator last );
 |  |  | 
 | 
|  | 
Reverses the order of the elements in the range [first, last).
[edit] Parameters
| first, last | - | the range of elements to reverse | 
[edit] Return value
(none)
[edit] Possible implementation
| template<class BidirectionalIterator>
void reverse(BidirectionalIterator first, BidirectionalIterator last)
{
    while ((first != last) && (first != --last)) {
        std::swap(*first++, *last);
    }
} | 
[edit] Example
[edit] Complexity
linear in the distance between first and last
[edit] See also
|  | 
|  | creates a copy of a range that is reversed (function template)
 |