map 插入元素

#include
#include
#include
using namespace std;
void fun(pair pr)
{
    cout << pr.first << pr.second << endl;//first代表键值,second代表实际值。
}
void MapConstruct()
{
     //重命名pair。
    typedef pair in_pair;
    
    //迭代函数,用于检测当map有相同键值时,实际值是否插入成功。
    pair::iterator, bool> pr;//

    //定义对象,并赋值。(插入值)
    map db;//<键值,实际值>
    db.insert(pair(1, 'a'));//需要和map的类型一一对应。
    db.insert(in_pair(2, 'b'));
    db.insert(in_pair(4, 'c'));
    db.insert(in_pair(10, 'c'));
    db.insert(in_pair(7, 'c'));
    db.insert(in_pair(6, 'c'));
    db.insert(in_pair(5, 'c'));
    
    //迭代函数,插入值
    map::iterator ite = db.begin();
    ite++;
    ite++;
    ite++;
    db.insert(ite,in_pair(3, 'c'));//插入的值并未被插入下标为四的位置,而是它应该存在的位置。

    //插入一段
    mapdb1;
    db1.insert(in_pair(8, 'b'));
    db1.insert(in_pair(9, 'b'));
    db1.insert(db.begin(),db.end());

    //初始化
    map db2(db1);
    mapdb3(db2.begin(),db2.end());

     //输出。
    for_each(db.begin(),db.end(),fun);
    for_each(db1.begin(),db1.end(),fun);
    for_each(db2.begin(),db2.end(),fun);
    for_each(db3.begin(),db3.end(),fun);
    
}
int main()
{
    MapConstruct();
    system("pause");
    return 0;
}

你可能感兴趣的:(蓝桥杯,c++,算法)