- C 标准库
- C 标准库
- C++ 标准库
- C++ 库 - 主页
- C++ 库 - <fstream>
- C++ 库 - <iomanip>
- C++ 库 - <ios>
- C++ 库 - <iosfwd>
- C++ 库 - <iostream>
- C++ 库 - <istream>
- C++ 库 - <ostream>
- C++ 库 - <sstream>
- C++ 库 - <streambuf>
- C++ 库 - <原子>
- C++ 库 - <复杂>
- C++ 库 - <异常>
- C++ 库 - <功能>
- C++ 库 - <限制>
- C++ 库 - <语言环境>
- C++ 库 - <内存>
- C++ 库 - <新>
- C++ 库 - <数字>
- C++ 库 - <正则表达式>
- C++ 库 - <stdexcept>
- C++ 库 - <字符串>
- C++ 库 - <线程>
- C++ 库 - <元组>
- C++ 库 - <类型信息>
- C++ 库 - <实用程序>
- C++ 库 - <valarray>
C++ 地图库 - multimap() 函数
描述
C++ 函数std::multimap::multimap()构造一个多重映射,其元素数量与第一个到最后一个范围内的元素数量相同。
宣言
以下是 std::multimap::multimap() 函数形式 std::map 标头的声明。
C++98
template <class InputIterator>
multimap (InputIterator first, InputIterator last,
const key_compare& comp = key_compare(),
const allocator_type& alloc = allocator_type());
C++11
template <class InputIterator>
multimap (InputIterator first, InputIterator last,
const key_compare& comp = key_compare(),
const allocator_type& = allocator_type());
参数
first - 将迭代器输入到初始位置。
最后- 输入迭代器到最终位置。
comp - 一个二元谓词,它接受两个关键参数,如果第一个参数在第二个参数之前,则返回 true,否则返回 false。默认情况下它使用 less 谓词。
alloc - 分配器对象。
返回值
构造函数永远不会返回值。
例外情况
如果抛出异常,对容器没有影响。
时间复杂度
线性即 O(n)
例子
以下示例显示了 std::multimap::multimap() 函数的用法。
#include <iostream>
#include <map>
using namespace std;
int main(void) {
/* Multimap with duplicates */
multimap<char, int> m1 = {
{'a', 1},
{'a', 2},
{'b', 3},
{'c', 4},
{'c', 5},
};
multimap<char, int>m2(m1.begin(), m1.end());
cout << "Multimap contains following elements:" << endl;
for (auto it = m2.begin(); it != m2.end(); ++it)
cout << it->first << " = " << it->second << endl;
return 0;
}
让我们编译并运行上面的程序,这将产生以下结果 -
Multimap contains following elements: a = 1 a = 2 b = 3 c = 4 c = 5
地图.htm