A<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2B%2B%2FSTL_Algorithms_Modifying_sequence_operations%2Ftransform</id>
		<title>C++/STL Algorithms Modifying sequence operations/transform - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.cppe.ru/index.php?action=history&amp;feed=atom&amp;title=C%2B%2B%2FSTL_Algorithms_Modifying_sequence_operations%2Ftransform"/>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B/STL_Algorithms_Modifying_sequence_operations/transform&amp;action=history"/>
		<updated>2026-04-18T19:15:37Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C%2B%2B/STL_Algorithms_Modifying_sequence_operations/transform&amp;diff=1983&amp;oldid=prev</id>
		<title> в 14:21, 25 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B/STL_Algorithms_Modifying_sequence_operations/transform&amp;diff=1983&amp;oldid=prev"/>
				<updated>2010-05-25T14:21:06Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 14:21, 25 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.cppe.ru/index.php?title=C%2B%2B/STL_Algorithms_Modifying_sequence_operations/transform&amp;diff=1984&amp;oldid=prev</id>
		<title>Admin: 1 версия:&amp;#32;Импорт контента...</title>
		<link rel="alternate" type="text/html" href="http://www.cppe.ru/index.php?title=C%2B%2B/STL_Algorithms_Modifying_sequence_operations/transform&amp;diff=1984&amp;oldid=prev"/>
				<updated>2010-05-25T10:28:21Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия: Импорт контента...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;==Compute the difference==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;iomanip&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
void print(T&amp;amp; c){&lt;br /&gt;
   for( typename T::iterator i = c.begin(); i != c.end(); i++ ){&lt;br /&gt;
      std::cout &amp;lt;&amp;lt; *i &amp;lt;&amp;lt; endl;&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
   const float d1[] = { 1.11, 2.22, 3.33, 4.44, 5.55 };&lt;br /&gt;
   const float d2[] = { 6.66, 7.77, 8.88, 9.99, 1.11 };&lt;br /&gt;
   vector&amp;lt;float&amp;gt; v2( d2,d2 + sizeof( d2 ) / sizeof( d2[0] ) );&lt;br /&gt;
   vector&amp;lt;float&amp;gt; v1( d1,d1 + sizeof( d1 ) / sizeof( d1[0] ) );&lt;br /&gt;
   vector&amp;lt;float&amp;gt; change( v2.size() );&lt;br /&gt;
   transform( v2.begin(), v2.end(), v1.begin(),change.begin(), minus&amp;lt;float&amp;gt;() );&lt;br /&gt;
   print( change );&lt;br /&gt;
}&lt;br /&gt;
  &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Create a sequence that contains the midpoints between the values in two other sequences.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
double reciprocal(double val);&lt;br /&gt;
template&amp;lt;class T&amp;gt; void show(const char *msg, vector&amp;lt;T&amp;gt; vect);&lt;br /&gt;
int main(){&lt;br /&gt;
  int i;&lt;br /&gt;
  vector&amp;lt;double&amp;gt; v;&lt;br /&gt;
  for(i=1; i &amp;lt; 10; ++i) &lt;br /&gt;
     v.push_back((double)i);&lt;br /&gt;
  show(&amp;quot;Initial contents of v:&amp;quot;, v);&lt;br /&gt;
  cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
  vector&amp;lt;double&amp;gt; v2(10);&lt;br /&gt;
  transform(v.begin(), v.end(), v2.begin(), reciprocal);&lt;br /&gt;
  show(&amp;quot;v2:&amp;quot;, v2);&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
template&amp;lt;class T&amp;gt; void show(const char *msg, vector&amp;lt;T&amp;gt; vect) {&lt;br /&gt;
  cout &amp;lt;&amp;lt; msg &amp;lt;&amp;lt; endl;&lt;br /&gt;
  for(unsigned i=0; i &amp;lt; vect.size(); ++i)&lt;br /&gt;
    cout &amp;lt;&amp;lt; vect[i] &amp;lt;&amp;lt; endl;&lt;br /&gt;
}&lt;br /&gt;
// Return the reciprocal&lt;br /&gt;
double reciprocal(double val) {&lt;br /&gt;
  if(val == 0.0) &lt;br /&gt;
     return 0.0;&lt;br /&gt;
  return 1.0 / val; &lt;br /&gt;
}&lt;br /&gt;
  &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Demonstrate both unary and binary function objects.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
// A function object that computes a reciprocal.&lt;br /&gt;
class reciprocal : unary_function&amp;lt;double, double&amp;gt; {&lt;br /&gt;
public:&lt;br /&gt;
  result_type sum;&lt;br /&gt;
result_type operator()(argument_type val) {&lt;br /&gt;
    if(val == 0.0) &lt;br /&gt;
       return 0.0;&lt;br /&gt;
    return 1.0 / val; // return reciprocal&lt;br /&gt;
  }&lt;br /&gt;
};&lt;br /&gt;
int main(){&lt;br /&gt;
  int i;&lt;br /&gt;
  vector&amp;lt;double&amp;gt; v;&lt;br /&gt;
  for(i=1; i &amp;lt; 10; ++i) v.push_back((double)i);&lt;br /&gt;
  transform(v.begin(), v.end(), v.begin(), reciprocal());&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
  &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==demonstrate the two-sequence form of transform()==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int midpoint(int a, int b);&lt;br /&gt;
template&amp;lt;class T&amp;gt; void show(const char *msg, vector&amp;lt;T&amp;gt; vect);&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
  int i;&lt;br /&gt;
  vector&amp;lt;double&amp;gt; v;&lt;br /&gt;
  for(i=1; i &amp;lt; 10; ++i) &lt;br /&gt;
     v.push_back((double)i);&lt;br /&gt;
  show(&amp;quot;Initial contents of v:&amp;quot;, v);&lt;br /&gt;
  vector&amp;lt;int&amp;gt; v3, v4, v5(10);&lt;br /&gt;
  for(i = 0; i &amp;lt; 10; ++i) &lt;br /&gt;
     v3.push_back(i);&lt;br /&gt;
  for(i = 10; i &amp;lt; 20; ++i) {&lt;br /&gt;
     if(i%2) {&lt;br /&gt;
        v4.push_back(i); &lt;br /&gt;
     }else {&lt;br /&gt;
        v4.push_back(-i);&lt;br /&gt;
     }&lt;br /&gt;
  }&lt;br /&gt;
  show(&amp;quot;Contents of v3:&amp;quot;, v3);&lt;br /&gt;
  show(&amp;quot;Contents of v4:&amp;quot;, v4);&lt;br /&gt;
  transform(v3.begin(), v3.end(), v4.begin(), v5.begin(), midpoint);&lt;br /&gt;
  show(&amp;quot;Contents of v5:&amp;quot;, v5);&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
template&amp;lt;class T&amp;gt; void show(const char *msg, vector&amp;lt;T&amp;gt; vect) {&lt;br /&gt;
  cout &amp;lt;&amp;lt; msg &amp;lt;&amp;lt; endl;&lt;br /&gt;
  for(unsigned i=0; i &amp;lt; vect.size(); ++i)&lt;br /&gt;
    cout &amp;lt;&amp;lt; vect[i] &amp;lt;&amp;lt; endl;&lt;br /&gt;
}&lt;br /&gt;
// Return the whole-number midpoint between two values.&lt;br /&gt;
int midpoint(int a, int b) {&lt;br /&gt;
  return((a-b) / 2) + b;&lt;br /&gt;
}&lt;br /&gt;
  &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==std::transform with predicate==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
using std::cout;&lt;br /&gt;
using std::endl;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;numeric&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;iterator&amp;gt;&lt;br /&gt;
int calculateCube( int );&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
   std::ostream_iterator&amp;lt; int &amp;gt; output( cout, &amp;quot; &amp;quot; );&lt;br /&gt;
   int a2[ 10 ] = { 100, 2, 8, 1, 50, 3, 8, 8, 9, 10 };&lt;br /&gt;
   std::vector&amp;lt; int &amp;gt; v2( a2, a2 + 10 ); // copy of a2&lt;br /&gt;
   cout &amp;lt;&amp;lt; &amp;quot;Vector v2 contains: &amp;quot;;&lt;br /&gt;
   std::copy( v2.begin(), v2.end(), output );&lt;br /&gt;
   std::vector&amp;lt; int &amp;gt; cubes( 10 ); // instantiate vector cubes&lt;br /&gt;
   // calculate cube of each element in v; place results in cubes&lt;br /&gt;
   std::transform( v2.begin(), v2.end(), cubes.begin(), calculateCube );&lt;br /&gt;
   cout &amp;lt;&amp;lt; &amp;quot;\n\nThe cube of every integer in Vector v is:\n&amp;quot;;&lt;br /&gt;
   std::copy( cubes.begin(), cubes.end(), output );&lt;br /&gt;
&lt;br /&gt;
   cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
   return 0;&lt;br /&gt;
}&lt;br /&gt;
int calculateCube( int value )&lt;br /&gt;
{&lt;br /&gt;
   return value * value * value;&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
Vector v2 contains: 100 2 8 1 50 3 8 8 9 10&lt;br /&gt;
The cube of every integer in Vector v is:&lt;br /&gt;
1000000 8 512 1 125000 27 512 512 729 1000&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Subtract the mean from every data point==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;cmath&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;list&amp;gt;&lt;br /&gt;
#include &amp;lt;numeric&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
void print(T&amp;amp; c){&lt;br /&gt;
   for( typename T::iterator i = c.begin(); i != c.end(); i++ ){&lt;br /&gt;
      std::cout &amp;lt;&amp;lt; *i &amp;lt;&amp;lt; endl;&lt;br /&gt;
   }&lt;br /&gt;
}&lt;br /&gt;
int main(){&lt;br /&gt;
   const float a[] = { 1, 1.3, 1.5, 0.9, 0.1, 0.2};&lt;br /&gt;
   vector&amp;lt;float&amp;gt; data( a,a + sizeof( a ) / sizeof( a[0] ) );&lt;br /&gt;
   cout &amp;lt;&amp;lt; data.size() &amp;lt;&amp;lt; &amp;quot; ELEMENTS\n&amp;quot;;&lt;br /&gt;
   print( data  );&lt;br /&gt;
   // compute the mean&lt;br /&gt;
   float mean = accumulate( data.begin(), data.end(), 0.0f )/ data.size();&lt;br /&gt;
   // subtract the mean from every data point&lt;br /&gt;
   vector&amp;lt;float&amp;gt; zero_mean( data );&lt;br /&gt;
   transform( zero_mean.begin(), zero_mean.end(), zero_mean.begin(),bind2nd( minus&amp;lt;float&amp;gt;(), mean ) );&lt;br /&gt;
   print( zero_mean );&lt;br /&gt;
}&lt;br /&gt;
  &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Transform all elements into deque from set by multiplying 10==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;The C++ Standard Library - A Tutorial and Reference&amp;quot;&lt;br /&gt;
 * by Nicolai M. Josuttis, Addison-Wesley, 1999&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright Nicolai M. Josuttis 1999.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;set&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
/* PRINT_ELEMENTS()&lt;br /&gt;
 * - prints optional C-string optcstr followed by&lt;br /&gt;
 * - all elements of the collection coll&lt;br /&gt;
 * - separated by spaces&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void PRINT_ELEMENTS (const T&amp;amp; coll, const char* optcstr=&amp;quot;&amp;quot;)&lt;br /&gt;
{&lt;br /&gt;
    typename T::const_iterator pos;&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; optcstr;&lt;br /&gt;
    for (pos=coll.begin(); pos!=coll.end(); ++pos) {&lt;br /&gt;
        std::cout &amp;lt;&amp;lt; *pos &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; std::endl;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    set&amp;lt;int,greater&amp;lt;int&amp;gt; &amp;gt; coll1;&lt;br /&gt;
    deque&amp;lt;int&amp;gt; coll2;&lt;br /&gt;
    // insert elements from 1 to 9&lt;br /&gt;
    for (int i=1; i&amp;lt;=9; ++i) {&lt;br /&gt;
        coll1.insert(i);&lt;br /&gt;
    }&lt;br /&gt;
    PRINT_ELEMENTS(coll1,&amp;quot;initialized: &amp;quot;);&lt;br /&gt;
    // transform all elements into coll2 by multiplying 10&lt;br /&gt;
    transform (coll1.begin(),coll1.end(),        // source&lt;br /&gt;
               back_inserter(coll2),             // destination&lt;br /&gt;
               bind2nd(multiplies&amp;lt;int&amp;gt;(),10));   // operation&lt;br /&gt;
    PRINT_ELEMENTS(coll2,&amp;quot;transformed: &amp;quot;);&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
initialized: 9 8 7 6 5 4 3 2 1&lt;br /&gt;
transformed: 90 80 70 60 50 40 30 20 10&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use a binary function object to find the midpoints between elements in v3 and v4 and store the results in v5.==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
// finds the midpoint between two values.&lt;br /&gt;
class midpoint : binary_function&amp;lt;int, int, double&amp;gt; {&lt;br /&gt;
public:&lt;br /&gt;
  result_type operator()(first_argument_type a, second_argument_type b) {&lt;br /&gt;
    return((a-b) / 2) + b;&lt;br /&gt;
  }&lt;br /&gt;
};&lt;br /&gt;
int main(){&lt;br /&gt;
  int i;&lt;br /&gt;
  vector&amp;lt;int&amp;gt; v3, v4, v5(10);&lt;br /&gt;
  for(i = 0; i &amp;lt; 10; ++i) &lt;br /&gt;
     v3.push_back(i);&lt;br /&gt;
  for(i = 10; i &amp;lt; 20; ++i) &lt;br /&gt;
     if(i%2) &lt;br /&gt;
        v4.push_back(i); &lt;br /&gt;
     else &lt;br /&gt;
        v4.push_back(-i);&lt;br /&gt;
  transform(v3.begin(), v3.end(), v4.begin(), v5.begin(), midpoint());&lt;br /&gt;
  return 0;&lt;br /&gt;
}&lt;br /&gt;
  &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use generic template function with transform==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;C++ Templates - The Complete Guide&amp;quot;&lt;br /&gt;
 * by David Vandevoorde and Nicolai M. Josuttis, Addison-Wesley, 2002&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright David Vandevoorde and Nicolai M. Josuttis 2002.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
template &amp;lt;typename T, int VAL&amp;gt;&lt;br /&gt;
T addValue (T const&amp;amp; x)&lt;br /&gt;
{&lt;br /&gt;
    return x + VAL;&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
void call_addValue()&lt;br /&gt;
{&lt;br /&gt;
    addValue&amp;lt;int,5&amp;gt;(42);&lt;br /&gt;
}&lt;br /&gt;
template &amp;lt;typename IT, typename OP&amp;gt;&lt;br /&gt;
void transform (IT beg, IT end, IT to, OP op)&lt;br /&gt;
{&lt;br /&gt;
    while (beg != end) {&lt;br /&gt;
        *to++ = op(*beg++);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    call_addValue();&lt;br /&gt;
    int m[] = { 1, 2, 3, 4, 5, 6 };&lt;br /&gt;
    transform (m, m+6,&lt;br /&gt;
               m,&lt;br /&gt;
               (int(*)(int const&amp;amp;))    // cast necessary&lt;br /&gt;
               addValue&amp;lt;int,5&amp;gt;);&lt;br /&gt;
    for(int i=0;i&amp;lt;6;i++){&lt;br /&gt;
       cout &amp;lt;&amp;lt; m[i] &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
6 7 8 9 10 11&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use transform function to square all elements in an array==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;The C++ Standard Library - A Tutorial and Reference&amp;quot;&lt;br /&gt;
 * by Nicolai M. Josuttis, Addison-Wesley, 1999&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright Nicolai M. Josuttis 1999.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;iterator&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    int coll[] = { 5, 6, 2, 4, 1, 3 };&lt;br /&gt;
    // square all elements&lt;br /&gt;
    transform (coll, coll+6,        // first source&lt;br /&gt;
               coll,                // second source&lt;br /&gt;
               coll,                // destination&lt;br /&gt;
               multiplies&amp;lt;int&amp;gt;());  // operation&lt;br /&gt;
    // print all elements&lt;br /&gt;
    copy (coll, coll+6,&lt;br /&gt;
          ostream_iterator&amp;lt;int&amp;gt;(cout,&amp;quot; &amp;quot;));&lt;br /&gt;
    cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
25 36 4 16 1 9&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use transform to add each element traversed forward with each element traversed backward==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
    &lt;br /&gt;
/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;The C++ Standard Library - A Tutorial and Reference&amp;quot;&lt;br /&gt;
 * by Nicolai M. Josuttis, Addison-Wesley, 1999&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright Nicolai M. Josuttis 1999.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;list&amp;gt;&lt;br /&gt;
#include &amp;lt;set&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;iterator&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;numeric&amp;gt;&lt;br /&gt;
/* PRINT_ELEMENTS()&lt;br /&gt;
 * - prints optional C-string optcstr followed by&lt;br /&gt;
 * - all elements of the collection coll&lt;br /&gt;
 * - separated by spaces&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void PRINT_ELEMENTS (const T&amp;amp; coll, const char* optcstr=&amp;quot;&amp;quot;)&lt;br /&gt;
{&lt;br /&gt;
    typename T::const_iterator pos;&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; optcstr;&lt;br /&gt;
    for (pos=coll.begin(); pos!=coll.end(); ++pos) {&lt;br /&gt;
        std::cout &amp;lt;&amp;lt; *pos &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; std::endl;&lt;br /&gt;
}&lt;br /&gt;
/* INSERT_ELEMENTS (collection, first, last)&lt;br /&gt;
 * - fill values from first to last into the collection&lt;br /&gt;
 * - NOTE: NO half-open range&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void INSERT_ELEMENTS (T&amp;amp; coll, int first, int last)&lt;br /&gt;
{&lt;br /&gt;
    for (int i=first; i&amp;lt;=last; ++i) {&lt;br /&gt;
        coll.insert(coll.end(),i);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    vector&amp;lt;int&amp;gt; coll1;&lt;br /&gt;
    list&amp;lt;int&amp;gt; coll2;&lt;br /&gt;
    INSERT_ELEMENTS(coll1,1,9);&lt;br /&gt;
    PRINT_ELEMENTS(coll1,&amp;quot;coll1:   &amp;quot;);&lt;br /&gt;
    /* add each element traversed forward with each element traversed backward&lt;br /&gt;
     * and insert result into coll2&lt;br /&gt;
     */&lt;br /&gt;
    transform (coll1.begin(), coll1.end(),       // first source range&lt;br /&gt;
               coll1.rbegin(),                   // second source range&lt;br /&gt;
               back_inserter(coll2),             // destination range&lt;br /&gt;
               plus&amp;lt;int&amp;gt;());                     // operation&lt;br /&gt;
    PRINT_ELEMENTS(coll2,&amp;quot;coll2:   &amp;quot;);&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
coll1:   1 2 3 4 5 6 7 8 9&lt;br /&gt;
coll2:   10 10 10 10 10 10 10 10 10&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use transform to make the numbers in a list go from a certain range==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;cstdlib&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;list&amp;gt;&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main( )&lt;br /&gt;
{&lt;br /&gt;
   list&amp;lt;int&amp;gt; data( 100000 );&lt;br /&gt;
   // create random numbers&lt;br /&gt;
   generate( data.begin(), data.end(), rand );&lt;br /&gt;
   // make them go from 0 to 200&lt;br /&gt;
   transform( data.begin(), data.end(), data.begin(),bind2nd( modulus&amp;lt;int&amp;gt;(), 201 ) );&lt;br /&gt;
   // make them go from -100 to 100&lt;br /&gt;
   transform( data.begin(), data.end(), data.begin(),bind2nd( minus&amp;lt;int&amp;gt;(), 100 ) );&lt;br /&gt;
&lt;br /&gt;
}&lt;br /&gt;
  &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use transform to negate all elements in a container==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
    &lt;br /&gt;
/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;The C++ Standard Library - A Tutorial and Reference&amp;quot;&lt;br /&gt;
 * by Nicolai M. Josuttis, Addison-Wesley, 1999&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright Nicolai M. Josuttis 1999.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;list&amp;gt;&lt;br /&gt;
#include &amp;lt;set&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;iterator&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;numeric&amp;gt;&lt;br /&gt;
/* PRINT_ELEMENTS()&lt;br /&gt;
 * - prints optional C-string optcstr followed by&lt;br /&gt;
 * - all elements of the collection coll&lt;br /&gt;
 * - separated by spaces&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void PRINT_ELEMENTS (const T&amp;amp; coll, const char* optcstr=&amp;quot;&amp;quot;)&lt;br /&gt;
{&lt;br /&gt;
    typename T::const_iterator pos;&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; optcstr;&lt;br /&gt;
    for (pos=coll.begin(); pos!=coll.end(); ++pos) {&lt;br /&gt;
        std::cout &amp;lt;&amp;lt; *pos &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; std::endl;&lt;br /&gt;
}&lt;br /&gt;
/* INSERT_ELEMENTS (collection, first, last)&lt;br /&gt;
 * - fill values from first to last into the collection&lt;br /&gt;
 * - NOTE: NO half-open range&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void INSERT_ELEMENTS (T&amp;amp; coll, int first, int last)&lt;br /&gt;
{&lt;br /&gt;
    for (int i=first; i&amp;lt;=last; ++i) {&lt;br /&gt;
        coll.insert(coll.end(),i);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    vector&amp;lt;int&amp;gt; coll1;&lt;br /&gt;
    list&amp;lt;int&amp;gt; coll2;&lt;br /&gt;
    INSERT_ELEMENTS(coll1,1,9);&lt;br /&gt;
    PRINT_ELEMENTS(coll1,&amp;quot;coll1:   &amp;quot;);&lt;br /&gt;
    // negate all elements in coll1&lt;br /&gt;
    transform (coll1.begin(), coll1.end(),      // source range&lt;br /&gt;
               coll1.begin(),                   // destination range&lt;br /&gt;
               negate&amp;lt;int&amp;gt;());                  // operation&lt;br /&gt;
    PRINT_ELEMENTS(coll1,&amp;quot;negated: &amp;quot;);&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
coll1:   1 2 3 4 5 6 7 8 9&lt;br /&gt;
negated: -1 -2 -3 -4 -5 -6 -7 -8 -9&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use transform to print differences of two corresponding elements==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
    &lt;br /&gt;
/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;The C++ Standard Library - A Tutorial and Reference&amp;quot;&lt;br /&gt;
 * by Nicolai M. Josuttis, Addison-Wesley, 1999&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright Nicolai M. Josuttis 1999.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;list&amp;gt;&lt;br /&gt;
#include &amp;lt;set&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;iterator&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;numeric&amp;gt;&lt;br /&gt;
/* PRINT_ELEMENTS()&lt;br /&gt;
 * - prints optional C-string optcstr followed by&lt;br /&gt;
 * - all elements of the collection coll&lt;br /&gt;
 * - separated by spaces&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void PRINT_ELEMENTS (const T&amp;amp; coll, const char* optcstr=&amp;quot;&amp;quot;)&lt;br /&gt;
{&lt;br /&gt;
    typename T::const_iterator pos;&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; optcstr;&lt;br /&gt;
    for (pos=coll.begin(); pos!=coll.end(); ++pos) {&lt;br /&gt;
        std::cout &amp;lt;&amp;lt; *pos &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; std::endl;&lt;br /&gt;
}&lt;br /&gt;
/* INSERT_ELEMENTS (collection, first, last)&lt;br /&gt;
 * - fill values from first to last into the collection&lt;br /&gt;
 * - NOTE: NO half-open range&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void INSERT_ELEMENTS (T&amp;amp; coll, int first, int last)&lt;br /&gt;
{&lt;br /&gt;
    for (int i=first; i&amp;lt;=last; ++i) {&lt;br /&gt;
        coll.insert(coll.end(),i);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    vector&amp;lt;int&amp;gt; coll1;&lt;br /&gt;
    list&amp;lt;int&amp;gt; coll2;&lt;br /&gt;
    INSERT_ELEMENTS(coll1,1,9);&lt;br /&gt;
    PRINT_ELEMENTS(coll1,&amp;quot;coll1:   &amp;quot;);&lt;br /&gt;
    // print differences of two corresponding elements&lt;br /&gt;
    cout &amp;lt;&amp;lt; &amp;quot;diff:    &amp;quot;;&lt;br /&gt;
    transform (coll1.begin(), coll1.end(),       // first source range&lt;br /&gt;
               coll2.begin(),                    // second source range&lt;br /&gt;
               ostream_iterator&amp;lt;int&amp;gt;(cout, &amp;quot; &amp;quot;), // destination range&lt;br /&gt;
               minus&amp;lt;int&amp;gt;());                    // operation&lt;br /&gt;
    cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
coll1:   1 2 3 4 5 6 7 8 9&lt;br /&gt;
diff:    2 3 4 5 6 7 8 9 10&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use transform to print elements negatively and in reverse order==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
    &lt;br /&gt;
/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;The C++ Standard Library - A Tutorial and Reference&amp;quot;&lt;br /&gt;
 * by Nicolai M. Josuttis, Addison-Wesley, 1999&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright Nicolai M. Josuttis 1999.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;list&amp;gt;&lt;br /&gt;
#include &amp;lt;set&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;iterator&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;numeric&amp;gt;&lt;br /&gt;
/* PRINT_ELEMENTS()&lt;br /&gt;
 * - prints optional C-string optcstr followed by&lt;br /&gt;
 * - all elements of the collection coll&lt;br /&gt;
 * - separated by spaces&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void PRINT_ELEMENTS (const T&amp;amp; coll, const char* optcstr=&amp;quot;&amp;quot;)&lt;br /&gt;
{&lt;br /&gt;
    typename T::const_iterator pos;&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; optcstr;&lt;br /&gt;
    for (pos=coll.begin(); pos!=coll.end(); ++pos) {&lt;br /&gt;
        std::cout &amp;lt;&amp;lt; *pos &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; std::endl;&lt;br /&gt;
}&lt;br /&gt;
/* INSERT_ELEMENTS (collection, first, last)&lt;br /&gt;
 * - fill values from first to last into the collection&lt;br /&gt;
 * - NOTE: NO half-open range&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void INSERT_ELEMENTS (T&amp;amp; coll, int first, int last)&lt;br /&gt;
{&lt;br /&gt;
    for (int i=first; i&amp;lt;=last; ++i) {&lt;br /&gt;
        coll.insert(coll.end(),i);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    vector&amp;lt;int&amp;gt; coll1;&lt;br /&gt;
    list&amp;lt;int&amp;gt; coll2;&lt;br /&gt;
    INSERT_ELEMENTS(coll1,1,9);&lt;br /&gt;
    PRINT_ELEMENTS(coll1,&amp;quot;coll1:   &amp;quot;);&lt;br /&gt;
    // print coll2 negatively and in reverse order&lt;br /&gt;
    transform (coll2.rbegin(), coll2.rend(),    // source range&lt;br /&gt;
               ostream_iterator&amp;lt;int&amp;gt;(cout,&amp;quot; &amp;quot;), // destination range&lt;br /&gt;
               negate&amp;lt;int&amp;gt;());                  // operation&lt;br /&gt;
    cout &amp;lt;&amp;lt; endl;&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
coll1:   1 2 3 4 5 6 7 8 9&lt;br /&gt;
&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use transform to square each element==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
    &lt;br /&gt;
/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;The C++ Standard Library - A Tutorial and Reference&amp;quot;&lt;br /&gt;
 * by Nicolai M. Josuttis, Addison-Wesley, 1999&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright Nicolai M. Josuttis 1999.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;list&amp;gt;&lt;br /&gt;
#include &amp;lt;set&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;iterator&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;numeric&amp;gt;&lt;br /&gt;
/* PRINT_ELEMENTS()&lt;br /&gt;
 * - prints optional C-string optcstr followed by&lt;br /&gt;
 * - all elements of the collection coll&lt;br /&gt;
 * - separated by spaces&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void PRINT_ELEMENTS (const T&amp;amp; coll, const char* optcstr=&amp;quot;&amp;quot;)&lt;br /&gt;
{&lt;br /&gt;
    typename T::const_iterator pos;&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; optcstr;&lt;br /&gt;
    for (pos=coll.begin(); pos!=coll.end(); ++pos) {&lt;br /&gt;
        std::cout &amp;lt;&amp;lt; *pos &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; std::endl;&lt;br /&gt;
}&lt;br /&gt;
/* INSERT_ELEMENTS (collection, first, last)&lt;br /&gt;
 * - fill values from first to last into the collection&lt;br /&gt;
 * - NOTE: NO half-open range&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void INSERT_ELEMENTS (T&amp;amp; coll, int first, int last)&lt;br /&gt;
{&lt;br /&gt;
    for (int i=first; i&amp;lt;=last; ++i) {&lt;br /&gt;
        coll.insert(coll.end(),i);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    vector&amp;lt;int&amp;gt; coll1;&lt;br /&gt;
    list&amp;lt;int&amp;gt; coll2;&lt;br /&gt;
    INSERT_ELEMENTS(coll1,1,9);&lt;br /&gt;
    PRINT_ELEMENTS(coll1,&amp;quot;coll1:   &amp;quot;);&lt;br /&gt;
    // square each element&lt;br /&gt;
    transform (coll1.begin(), coll1.end(),       // first source range&lt;br /&gt;
               coll1.begin(),                    // second source range&lt;br /&gt;
               coll1.begin(),                    // destination range&lt;br /&gt;
               multiplies&amp;lt;int&amp;gt;());               // operation&lt;br /&gt;
    PRINT_ELEMENTS(coll1,&amp;quot;squared: &amp;quot;);&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
coll1:   1 2 3 4 5 6 7 8 9&lt;br /&gt;
squared: 1 4 9 16 25 36 49 64 81&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
==Use transform to transform elements in one container into another container with ten times their value==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
&amp;lt;source lang=&amp;quot;cpp&amp;quot;&amp;gt;  &lt;br /&gt;
 &lt;br /&gt;
    &lt;br /&gt;
/* The following code example is taken from the book&lt;br /&gt;
 * &amp;quot;The C++ Standard Library - A Tutorial and Reference&amp;quot;&lt;br /&gt;
 * by Nicolai M. Josuttis, Addison-Wesley, 1999&lt;br /&gt;
 *&lt;br /&gt;
 * (C) Copyright Nicolai M. Josuttis 1999.&lt;br /&gt;
 * Permission to copy, use, modify, sell and distribute this software&lt;br /&gt;
 * is granted provided this copyright notice appears in all copies.&lt;br /&gt;
 * This software is provided &amp;quot;as is&amp;quot; without express or implied&lt;br /&gt;
 * warranty, and with no claim as to its suitability for any purpose.&lt;br /&gt;
 */&lt;br /&gt;
#include &amp;lt;iostream&amp;gt;&lt;br /&gt;
#include &amp;lt;vector&amp;gt;&lt;br /&gt;
#include &amp;lt;deque&amp;gt;&lt;br /&gt;
#include &amp;lt;list&amp;gt;&lt;br /&gt;
#include &amp;lt;set&amp;gt;&lt;br /&gt;
#include &amp;lt;map&amp;gt;&lt;br /&gt;
#include &amp;lt;string&amp;gt;&lt;br /&gt;
#include &amp;lt;algorithm&amp;gt;&lt;br /&gt;
#include &amp;lt;iterator&amp;gt;&lt;br /&gt;
#include &amp;lt;functional&amp;gt;&lt;br /&gt;
#include &amp;lt;numeric&amp;gt;&lt;br /&gt;
/* PRINT_ELEMENTS()&lt;br /&gt;
 * - prints optional C-string optcstr followed by&lt;br /&gt;
 * - all elements of the collection coll&lt;br /&gt;
 * - separated by spaces&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void PRINT_ELEMENTS (const T&amp;amp; coll, const char* optcstr=&amp;quot;&amp;quot;)&lt;br /&gt;
{&lt;br /&gt;
    typename T::const_iterator pos;&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; optcstr;&lt;br /&gt;
    for (pos=coll.begin(); pos!=coll.end(); ++pos) {&lt;br /&gt;
        std::cout &amp;lt;&amp;lt; *pos &amp;lt;&amp;lt; &amp;quot; &amp;quot;;&lt;br /&gt;
    }&lt;br /&gt;
    std::cout &amp;lt;&amp;lt; std::endl;&lt;br /&gt;
}&lt;br /&gt;
/* INSERT_ELEMENTS (collection, first, last)&lt;br /&gt;
 * - fill values from first to last into the collection&lt;br /&gt;
 * - NOTE: NO half-open range&lt;br /&gt;
 */&lt;br /&gt;
template &amp;lt;class T&amp;gt;&lt;br /&gt;
inline void INSERT_ELEMENTS (T&amp;amp; coll, int first, int last)&lt;br /&gt;
{&lt;br /&gt;
    for (int i=first; i&amp;lt;=last; ++i) {&lt;br /&gt;
        coll.insert(coll.end(),i);&lt;br /&gt;
    }&lt;br /&gt;
}&lt;br /&gt;
using namespace std;&lt;br /&gt;
int main()&lt;br /&gt;
{&lt;br /&gt;
    vector&amp;lt;int&amp;gt; coll1;&lt;br /&gt;
    list&amp;lt;int&amp;gt; coll2;&lt;br /&gt;
    INSERT_ELEMENTS(coll1,1,9);&lt;br /&gt;
    PRINT_ELEMENTS(coll1,&amp;quot;coll1:   &amp;quot;);&lt;br /&gt;
    // transform elements of coll1 into coll2 with ten times their value&lt;br /&gt;
    transform (coll1.begin(), coll1.end(),      // source range&lt;br /&gt;
               back_inserter(coll2),            // destination range&lt;br /&gt;
               bind2nd(multiplies&amp;lt;int&amp;gt;(),10));  // operation&lt;br /&gt;
    PRINT_ELEMENTS(coll2,&amp;quot;coll2:   &amp;quot;);&lt;br /&gt;
}&lt;br /&gt;
/* &lt;br /&gt;
coll1:   1 2 3 4 5 6 7 8 9&lt;br /&gt;
coll2:   10 20 30 40 50 60 70 80 90&lt;br /&gt;
 */        &lt;br /&gt;
    &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>