CHAPTER10-9.cpp
上传用户:fjc899
上传日期:2007-07-03
资源大小:187k
文件大小:1k
源码类别:

STL

开发平台:

C/C++

  1. //文件名:CHAPTER10-9.cpp
  2. #include <map>
  3. #include <iostream>
  4. #if _MSC_VER > 1020   // if VC++ version is > 4.2
  5.    using namespace std;  // std c++ libs implemented in std
  6. #endif
  7. void main( )
  8. {
  9.    map <int, int> m1;
  10.    int i;
  11.    map <int, int> :: iterator m1_Iter;
  12.    map <int, int> :: reverse_iterator m1_rIter;
  13.    map <int, int> :: const_reverse_iterator m1_crIter;
  14.    typedef pair <int, int> Int_Pair;
  15.    m1.insert ( Int_Pair ( 1, 10 ) );
  16.    m1.insert ( Int_Pair ( 2, 20 ) );
  17.    m1.insert ( Int_Pair ( 3, 30 ) );
  18.    m1_rIter = m1.rend( );
  19.    m1_rIter--;
  20.    cout << "The last element of the reversed map m1 is "<< m1_rIter -> first << "." << endl;
  21.    // begin can be used to start an iteration through a map in a forward order
  22.    cout << "The map is: ";
  23.    for ( m1_Iter = m1.begin( ) ; m1_Iter != m1.end( ); m1_Iter++)
  24.       cout << m1_Iter -> first << " ";
  25.    cout << "." << endl;
  26.    // rbegin can be used to start an iteration through a map in a reverse order
  27.    cout << "The reversed map is: ";
  28.    for ( m1_rIter = m1.rbegin( ) ; m1_rIter != m1.rend( ); m1_rIter++)
  29.       cout << m1_rIter -> first << " ";
  30.   cout << "." << endl;
  31.    // A map element can be erased by dereferencing to its key 
  32.    m1_rIter = --m1.rend( );
  33.    m1.erase ( m1_rIter -> first );
  34.    m1_rIter = m1.rend( );
  35.    m1_rIter--;
  36.    cout << "After the erasure, the last element "<< "in the reversed map is "
  37.         << m1_rIter -> first << "." << endl;
  38. }