Mega Code Archive

 
Categories / C++ / Map Multimap
 

Const_reverse_iterator from a map

#include <algorithm> #include <functional> #include <iomanip> #include <iostream> #include <map> #include <string> #include <utility> #include <vector> using namespace std; class PC {    public:    enum PC_type { Dell, HP, IBM, Compaq };    PC( PC_type appliance = Dell, int model = 220,       int serial = 0 );    bool operator<( const PC& rhs ) const;    PC_type appliance() const;    int model() const;    string name() const;    void print() const;    int serial() const;    private:    PC_type appliance_;    int model_;    int serial_; }; inline PC::PC( PC::PC_type appliance, int model,    int serial )    : appliance_( appliance ), model_( model ), serial_( serial ) {} // empty inline bool PC::operator<( const PC& rhs ) const { return appliance() < rhs.appliance() ||    ( appliance() == rhs.appliance() && model() < rhs.model() ); } inline PC::PC_type PC::appliance() const { return appliance_; } inline int PC::model() const { return model_; } string PC::name() const {    string what;    switch( appliance() )    {       case Dell:    what = "Dell";               break;       case HP:      what = "HP";                 break;       case IBM:     what = "IBM";                break;       case Compaq:  what = "Compaq";             break;       default:      what = "Unknown appliance";  break;    }    return what; } inline void PC::print() const {    char oldfill = cout.fill();    cout << name() << " - Model "         << model() << ", Serial number "         << serial() << endl; } inline int PC::serial() const { return serial_; } bool greater_model( const pair<PC::PC_type,PC> p,int min_model ); int main( ) {    const PC::PC_type kind[] = { PC::IBM,       PC::IBM, PC::Dell, PC::HP,       PC::HP, PC::HP };    const int num_appliances = 3;    vector<PC> v;    for( int i = 0; i < num_appliances; ++i )       v.push_back( PC( kind[i], i, i ) );    map<int,PC> sold;    transform( kind, kind+num_appliances, v.begin(),inserter( sold, sold.end() ),make_pair<int,PC> );    map<int,PC>::const_iterator sold_end = sold.end();    map<int,PC>::const_iterator site;    for( site = sold.begin(); site != sold_end; ++site )       site->second.print();    map<int,PC>::const_reverse_iterator reverse_site;    map<int,PC>::const_reverse_iterator sold_rend = sold.rend();    const PC::PC_type desired_type = PC::IBM;    for( reverse_site = sold.rbegin(); reverse_site != sold_rend;++reverse_site )       if( reverse_site->second.appliance() == desired_type )          break;    if( reverse_site != sold_rend )       reverse_site->second.print();    else       cout << "No IBMs sold\n"; } inline bool greater_model( const pair<PC::PC_type,PC> p,int min_model ) { return p.second.model() >= min_model; }