📜  C++ STL中的multimap :: emplace_hint()

📅  最后修改于: 2021-05-30 03:44:35             🧑  作者: Mango

multimap :: emplace_hint()是C++ STL中的内置函数,该函数将键及其元素插入具有给定提示的multimap容器中。它可以有效地将容器大小增加一倍,因为multimap是存储具有相同值的多个键的容器。所提供的提示不会影响要输入的位置,它只会增加插入速度,因为它指向要开始搜索订购的位置。它以相同的顺序插入,紧随其后的是容器。它的工作原理类似于multimap :: emplace()函数,但有时比用户准确提供位置的速度要快。

句法:

multimap_name.emplace_hint(position, key, element)

参数:该函数接受三个强制性参数,如下所述:

  • key –指定要在多图容器中插入的键。
  • element –指定要在多图容器中插入的键的元素。
  • position –指定从中开始订购搜索操作的位置,从而使插入速度更快。

返回值:该函数不返回任何内容。

// C++ program to illustrate the
// multimap::emplace_hint() function
#include 
using namespace std;
  
int main()
{
  
    // initialize container
    multimap mp;
  
    // insert elements in random order
    mp.emplace_hint(mp.begin(), 2, 30); // faster
    mp.emplace_hint(mp.begin(), 1, 40); // faster
    mp.emplace_hint(mp.begin(), 2, 60); // slower
    mp.emplace_hint(mp.begin(), 2, 20); // slower
    mp.emplace_hint(mp.begin(), 1, 50); // faster
    mp.emplace_hint(mp.begin(), 1, 50); // faster
  
    // prints the elements
    cout << "\nThe multimap is : \n";
    cout << "KEY\tELEMENT\n";
    for (auto itr = mp.begin(); itr != mp.end(); itr++)
        cout << itr->first << "\t" << itr->second << endl;
  
    return 0;
}
输出:
The multimap is : 
KEY    ELEMENT
1    50
1    50
1    40
2    20
2    60
2    30
要从最佳影片策划和实践问题去学习,检查了C++基础课程为基础,以先进的C++和C++ STL课程基础加上STL。要完成从学习语言到DS Algo等的更多准备工作,请参阅“完整面试准备课程”