1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
|
#include <iostream>
#include <iterator>
#include <algorithm>
int main()
{
const auto is_odd = []( int i ) { return i%2 == 1 ; };
{
int a[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 } ;
for( int v : a ) std::cout << v << ' ' ;
std::cout << '\n' ;
auto mid = std::partition( std::begin(a), std::end(a), is_odd ) ;
for( auto iter = std::begin(a) ; iter != mid ; ++iter )
std::cout << *iter << ' ' ;
std::cout << " <partition> " ;
for( auto iter = mid ; iter != std::end(a) ; ++iter )
std::cout << *iter << ' ' ;
std::cout << "\n\n" ;
// 0 1 2 3 4 5 6 7 8 9
// 9 1 7 3 5 <partition> 4 6 2 8 0
}
{
int a[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 } ;
for( int v : a ) std::cout << v << ' ' ;
std::cout << '\n' ;
auto mid = std::stable_partition( std::begin(a), std::end(a), is_odd ) ;
for( auto iter = std::begin(a) ; iter != mid ; ++iter )
std::cout << *iter << ' ' ;
std::cout << " <stable_partition> " ;
for( auto iter = mid ; iter != std::end(a) ; ++iter )
std::cout << *iter << ' ' ;
std::cout << "\n\n" ;
// 0 1 2 3 4 5 6 7 8 9
// 1 3 5 7 9 <stable_partition> 0 2 4 6 8
}
{
int a[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 } ;
for( int v : a ) std::cout << v << ' ' ;
std::cout << '\n' ;
auto mid = std::remove_if( std::begin(a), std::end(a), is_odd ) ;
for( auto iter = std::begin(a) ; iter != mid ; ++iter )
std::cout << *iter << ' ' ;
std::cout << " <remove_if> " ;
for( auto iter = mid ; iter != std::end(a) ; ++iter )
std::cout << *iter << ' ' ;
std::cout << "\n\n" ;
// 0 1 2 3 4 5 6 7 8 9
// 0 2 4 6 8 <remove_if> 5 6 7 8 9
}
}
|