C++ Unordered_multimap 库 - insert() 函数


描述

C++ 函数std::unordered_multimap::insert()通过使用移动语义在 unordered_multimap 中插入新元素来扩展容器。此函数将容器大小增加一。

宣言

以下是 std::unordered_multimap::insert() 函数形式 std::unordered_map() 标头的声明。

C++11

template <class P>
iterator insert(const_iterator position, P&& val);

参数

  • position - 插入元素的位置的提示。

  • val - 要插入的值。

返回值

返回一个指向新插入元素的迭代器。

时间复杂度

常数,即平均情况下的 O(1)。

线性,即最坏情况下的 O(n)。

例子

以下示例显示了 std::unordered_multimap::insert() 函数的用法。

#include <iostream>
#include <unordered_map>

using namespace std;

int main(void) {
   unordered_multimap<char, int> umm = {
            {'b', 2},
            {'c', 3},
            {'d', 4},
         {'e', 5},
            };

   auto pos = umm.insert(umm.begin(), move(pair<char, int>('a', 1)));

   cout << "After inserting new element iterator poinst to "
       << pos->first << " = " << pos->second << endl;

   return 0;
}

让我们编译并运行上面的程序,这将产生以下结果 -

After inserting new element iterator poinst to a = 1
无序_map.htm