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

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

multimap::emplace_hint() 是C++ STL中的内置函数,其在multimap容器中插入给定提示的键和其元素。由于multimap是存储带有相同值的多个键的容器,因此它有效地将容器大小增加了一个。提供的提示不会影响要输入的位置,它只增加插入速度,因为它指向搜索排序要开始的位置。它按照容器所遵循的相同顺序插入。它的作用类似于multimap::emplace()函数,但如果用户正确提供了位置,则速度有时会更快。

语法:

multimap_name.emplace_hint(position, key, element)

参数: 该函数接受三个强制性参数,以下是它们的描述:

  • key- 要插入multimap容器的键。
  • element- 要插入multimap容器的与键关联的元素。
  • position- 指定搜索排序操作的开始位置,因此使插入更快。

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

// C++ program to illustrate the
// multimap::emplace_hint() function
#include <bits/stdc++.h>
using namespace std;
 
int main()
{
 
    // initialize container
    multimap<int, int> 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

Python教程

Java教程

Web教程

数据库教程

图形图像教程

大数据教程

开发工具教程

计算机教程

C++ 教程