multimap-rend

本文介绍了一个使用C++实现的multimap逆向迭代的例子。通过定义一个模板类ID来存储标识符和名称,并使用multimap存储整数键与ID实例的对应关系。演示了如何插入数据并利用reverse_iterator从multimap的末尾开始遍历,展示逆向迭代器的用法。
////////////////////////////////////////
//      2018/05/06 9:13:38
//      multimap-rend

// returns a reverse iterator to the beginning of the maltimap
#include <iostream>
#include <map>
#include <iomanip>
#include <string>

using namespace std;

template<class T>
class ID{
public:
    ID(T t, T n) :id(t), name(n){}
    void print(){
        cout.setf(ios::left);
        cout << setw(15) << name << " " << id << endl;
        cout.unsetf(ios::left);
    }
private:
    T id, name;
};

int main(){
    typedef ID<string> ld;
    typedef multimap<int, ld> M;
    typedef M::value_type v_t;

    M m;
    m.insert(v_t(1,ld("000123","Shevchenko")));
    m.insert(v_t(2,ld("000124","Pushkin")));
    m.insert(v_t(3,ld("000125","Shakespeare")));

    // same key
    m.insert(v_t(3,ld("000126","Smith")));

    M::reverse_iterator lt = m.rbegin();

    while (lt != m.rend()){
        cout.setf(ios::left);
        cout << setw(3) << lt->first;
        lt->second.print();
        lt++;
    }
    return 0;
}

/*
OUTPUT:
    3  Smith           000126
    3  Shakespeare     000125
    2  Pushkin         000124
    1  Shevchenko      000123
*/ 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值