#include<iostream>
#include<algorithm>
#include<vector>
#include<iterator>
using std::cout;
using std::endl;
int main()
{
const int SIZE = 10;
int a1[SIZE] = { 1, 3, 5, 7, 9, 1, 3, 5, 7, 9 };
std::vector< int > v1( a1, a1 + SIZE );
std::ostream_iterator< int > outputIt( cout, " " );
cout<<"Vector v1 contains: ";
std::copy( v1.begin(), v1.end(), outputIt );
std::inplace_merge( v1.begin(), v1.begin() + 5, v1.end() );
cout<<"/nAfter inplace_merge, v1 contains: ";
std::copy( v1.begin(), v1.end(), outputIt );
std::vector< int > results1;
std::unique_copy( v1.begin(), v1.end(), std::back_inserter( results1 ) );
cout<<"/nAfter unique copy results1 contains: ";
std::copy( results1.begin(), results1.end(), outputIt );
std::vector< int > results2;
cout<<"/nAfter reverse_copy, results2 contains: ";
std::reverse_copy( v1.begin(), v1.end(), std::back_inserter( results2 ) );
std::copy( results2.begin(), results2.end(), outputIt );
cout<<endl;
return 0;
}