C++ Unordered_map 库 - emplace() 函数
描述
C++ 函数 std::unordered_map::emplace() 通过插入新元素来扩展容器。
仅当 key 不存在时才进行插入。
声明
以下是 std::unordered_map::emplace() 函数形式 std::unordered_map 头的声明。
C++11
template <class... Args> pair<iterator, bool> emplace ( Args&&... args );
参数
args − 参数转发给元素的构造函数。
返回值
返回一个由 bool 组成的对来指示插入是否发生,并返回一个指向新插入元素的迭代器。
时间复杂度
常数,即平均情况下的 O(1)。
线性,即最坏情况下的 O(n)。
示例
以下示例显示了 std::unordered_map::emplace() 函数的用法。
#include <iostream> #include <unordered_map> using namespace std; int main(void) { unordered_map<char, int> um; um.emplace('a', 1); um.emplace('b', 2); um.emplace('c', 3); um.emplace('d', 4); um.emplace('e', 5); cout << "Unordered map contains following elements" << endl; for (auto it = um.begin(); it != um.end(); ++it) cout << it->first << " = " << it->second << endl; return 0; }
让我们编译并运行上面的程序,这将产生以下结果 −
Unordered map contains following elements e = 5 d = 4 c = 3 b = 2 a = 1