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

STL

开发平台:

C/C++

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