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

STL

开发平台:

C/C++

  1. //文件名:CHAPTER10-32.cpp
  2. #include <map>
  3. #include <iostream.h>
  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.    multimap <int, int> m1;
  10.    multimap <int, int> :: const_iterator m1_AcIter, m1_RcIter;
  11.    typedef pair <int, int> Int_Pair;
  12.    m1.insert ( Int_Pair ( 1, 10 ) );
  13.    m1.insert ( Int_Pair ( 2, 20 ) );
  14.    m1.insert ( Int_Pair ( 3, 20 ) );
  15.    m1.insert ( Int_Pair ( 3, 30 ) );
  16.    m1_RcIter = m1.lower_bound( 2 );
  17.    cout << "The element of multimap m1 with a key of 2 is: 20." << endl;
  18.    m1_RcIter = m1.lower_bound( 3 );
  19.    cout << "The first element of multimap m1 with a key of 3 is: "<< m1_RcIter -> second << "." << endl;
  20.    // If no match is found for the key, end( ) is returned
  21.    m1_RcIter = m1.lower_bound( 4 );
  22.    if ( m1_RcIter == m1.end( ) )
  23.       cout << "The multimap m1 doesn't have an element "<< "with a key of 4." << endl;
  24.    else
  25.       cout << "The element of multimap m1 with a key of 4 is: "<< m1_RcIter -> second << "." << endl;
  26.    // The element at a specific location in the multimap can be
  27.    // found using a dereferenced iterator addressing the location
  28.    m1_AcIter = m1.end( );
  29.    m1_AcIter--;
  30.    m1_RcIter = m1.lower_bound( m1_AcIter -> first );
  31.    cout << "The first element of m1 with a key matchingn"
  32.         << "that of the last element is: "<< m1_RcIter -> second << "." << endl;
  33.    // Note that the first element with a key equal to the key of the last element is not the last element
  34.    if ( m1_RcIter == --m1.end( ) )
  35.       cout << "This is the last element of multimap m1."<< endl;
  36.    else
  37.       cout << "This is not the last element of multimap m1."<< endl;
  38. }