c++11 标准模板(STL)(std::multimap)(二)
创始人
2024-05-24 17:02:59
0
定义于头文件 
template<

    class Key,
    class T,
    class Compare = std::less,
    class Allocator = std::allocator >

> class multimap;
(1)
namespace pmr {

    template >
    using multimap = std::multimap                                   std::pmr::polymorphic_allocator>>;

}
(2)(C++17 起)

 

multimap 是关联容器,含有关键-值 pair 的已排序列表,同时容许多个入口拥有同一关键。按照应用到关键的比较函数 Compare 排序。搜索、插入和移除操作拥有对数复杂度。

拥有等价关键的关键-值 pair 的顺序就是插入顺序,且不会更改。(C++11 起)

凡在标准库使用比较 (Compare) 概念出,都用描述于比较 (Compare) 上的等价关系确定等价性。不精确地说,若二个对象 ab 互不小于对方: !comp(a, b) && !comp(b, a) ,则认为它们等价。

成员函数

构造函数

std::multimap::multimap
multimap();

explicit multimap( const Compare& comp,

                   const Allocator& alloc = Allocator() );
(1)

explicit multimap( const Allocator& alloc );

(1)(C++11 起)
template< class InputIt >

multimap( InputIt first, InputIt last,
          const Compare& comp = Compare(),

          const Allocator& alloc = Allocator() );
(2)
template< class InputIt >

multimap( InputIt first, InputIt last,

          const Allocator& alloc );
(C++14 起)

multimap( const multimap& other );

(3)

multimap( const multimap& other, const Allocator& alloc );

(3)(C++11 起)

multimap( multimap&& other );

(4)(C++11 起)

multimap( multimap&& other, const Allocator& alloc );

(4)(C++11 起)
multimap( std::initializer_list init,

          const Compare& comp = Compare(),

          const Allocator& alloc = Allocator() );
(5)(C++11 起)

multimap( std::initializer_list init,
          const Allocator& );

(C++14 起)

 

从各种数据源构造新容器,可选地使用用户提供的分配器 alloc 或比较函数对象 comp

1) 构造空容器。

2) 构造容器,使之拥有范围 [first, last) 的内容。

3) 复制构造函数。构造容器,使之拥有 other 的内容副本。若不提供 alloc ,则通过调用 std::allocator_traits::select_on_container_copy_construction(other.get_allocator()) 获得分配器。

4) 移动构造函数。用移动语义构造容器,使之拥有 other 的内容。若不提供 alloc ,则从属于 other 的分配器移动构造分配器

5) 构造容器,使之拥有 initializer_list init 的内容。

参数

alloc-用于此容器所有内存分配的分配器
comp-用于所有关键比较的比较函数对象
first, last-复制元素来源的范围
other-要用作源以初始化容器元素的另一容器
init-用以初始化容器元素的 initializer_list
类型要求
- InputIt 必须满足遗留输入迭代器 (LegacyInputIterator) 的要求。
- Compare 必须满足比较 (Compare) 的要求。
- Allocator 必须满足分配器 (Allocator) 的要求。

复杂度

1) 常数。

2) N log(N) ,其中通常有 N = std::distance(first, last) ,若范围已为 value_comp() 所排序则与 N 成线性。

3) 与 other 的大小成线性。

4) 常数。若给定 alloc 且 alloc != other.get_allocator() 则为线性。

5) N log(N) ,其中通常有 N = init.size()) ,若 init 已按照 value_comp() 排序则与 N 成线性 。

异常

Allocator::allocate 的调用可能抛出。

注意

在容器移动构造(重载 (4) )后,指向 other 的引用及迭代器(除了尾迭代器)保持合法,但指代现于 *this 中的元素。当前标准由 [container.requirements.general]/12 中的总括陈述作出此保证,而 LWG 2321 正在考虑更严格的保证。

析构函数

std::multimap::~multimap

~multimap();

销毁容器。调用元素的析构函数,然后解分配所用的存储。注意,若元素是指针,则不销毁所指向的对象。

复杂度

与容器大小成线性。

调用示例

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include using namespace std;struct Cell
{int x;int y;Cell() = default;Cell(int a, int b): x(a), y(b) {}Cell &operator +=(const Cell &cell){x += cell.x;y += cell.y;return *this;}Cell &operator +(const Cell &cell){x += cell.x;y += cell.y;return *this;}Cell &operator *(const Cell &cell){x *= cell.x;y *= cell.y;return *this;}Cell &operator ++(){x += 1;y += 1;return *this;}bool operator <(const Cell &cell) const{if (x == cell.x){return y < cell.y;}else{return x < cell.x;}}bool operator >(const Cell &cell) const{if (x == cell.x){return y > cell.y;}else{return x > cell.x;}}bool operator ==(const Cell &cell) const{return x == cell.x && y == cell.y;}
};struct myCompare
{bool operator()(const int &a, const int &b){return a < b;}
};std::ostream &operator<<(std::ostream &os, const Cell &cell)
{os << "{" << cell.x << "," << cell.y << "}";return os;
}std::ostream &operator<<(std::ostream &os, const std::pair &pCell)
{os << pCell.first << "-" << pCell.second;return os;
}int main()
{std::cout << std::boolalpha;std::mt19937 g{std::random_device{}()};srand((unsigned)time(NULL));auto genKey = [](){return std::rand() % 10 + 100;};auto generate = [](){int n = std::rand() % 10 + 100;Cell cell{n, n};return cell;};//1) 构造空容器。std::multimap multimap1;std::cout << "multimap1 is empty: " << multimap1.empty() << std::endl;for (size_t index = 0; index < 5; index++){multimap1.insert({genKey(), generate()});}std::cout << std::endl;//2) 构造容器,使之拥有范围 [first, last) 的内容。std::multimap multimap2(multimap1.begin(), multimap1.end());std::cout << "multimap2:    ";std::copy(multimap2.begin(), multimap2.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;// 逆序std::multimap> multimap8(multimap1.begin(), multimap1.end());std::cout << "multimap8:    ";std::copy(multimap8.begin(), multimap8.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;std::cout << std::endl;//3) 复制构造函数。构造容器,使之拥有 other 的内容副本。std::multimap multimap3(multimap2);std::cout << "multimap3:    ";std::copy(multimap3.begin(), multimap3.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;std::multimap> multimap9(multimap8);std::cout << "multimap9:    ";std::copy(multimap9.begin(), multimap9.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;std::cout << std::endl;//4) 移动构造函数。用移动语义构造容器,使之拥有 other 的内容。std::multimap multimap4(std::move(multimap2));std::cout << "multimap4:    ";std::copy(multimap4.begin(), multimap4.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;std::cout << "multimap2(move) is empty: " << multimap2.empty() << std::endl;std::multimap> multimap10(std::move(multimap8));std::cout << "multimap10:   ";std::copy(multimap10.begin(), multimap10.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;std::cout << "multimap8(move) is empty: " << multimap10.empty() << std::endl;std::cout << std::endl;//5) 构造容器,使之拥有 initializer_list init 的内容。std::multimap multimap5({{genKey(), generate()}, {genKey(), generate()},{genKey(), generate()}, {genKey(), generate()}, {genKey(), generate()}});std::cout << "multimap5:    ";std::copy(multimap5.begin(), multimap5.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;std::multimap> multimap11({{genKey(), generate()}, {genKey(), generate()},{genKey(), generate()}, {genKey(), generate()}, {genKey(), generate()}});std::cout << "multimap11:   ";std::copy(multimap11.begin(), multimap11.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;std::cout << std::endl;//使用系统key比较函数std::multimap> multimap6({{genKey(), generate()}, {genKey(), generate()},{genKey(), generate()}, {genKey(), generate()}, {genKey(), generate()}});std::cout << "multimap6:    ";std::copy(multimap6.begin(), multimap6.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;std::cout << std::endl;//使用自定义key比较函数std::multimap multimap7({{genKey(), generate()}, {genKey(), generate()},{genKey(), generate()}, {genKey(), generate()}, {genKey(), generate()}});std::cout << "multimap7:    ";std::copy(multimap7.begin(), multimap7.end(), std::ostream_iterator>(std::cout, " "));std::cout << std::endl;return 0;
}

 

相关内容

热门资讯

喜欢穿一身黑的男生性格(喜欢穿... 今天百科达人给各位分享喜欢穿一身黑的男生性格的知识,其中也会对喜欢穿一身黑衣服的男人人好相处吗进行解...
发春是什么意思(思春和发春是什... 本篇文章极速百科给大家谈谈发春是什么意思,以及思春和发春是什么意思对应的知识点,希望对各位有所帮助,...
网络用语zl是什么意思(zl是... 今天给各位分享网络用语zl是什么意思的知识,其中也会对zl是啥意思是什么网络用语进行解释,如果能碰巧...
为什么酷狗音乐自己唱的歌不能下... 本篇文章极速百科小编给大家谈谈为什么酷狗音乐自己唱的歌不能下载到本地?,以及为什么酷狗下载的歌曲不是...
华为下载未安装的文件去哪找(华... 今天百科达人给各位分享华为下载未安装的文件去哪找的知识,其中也会对华为下载未安装的文件去哪找到进行解...
怎么往应用助手里添加应用(应用... 今天百科达人给各位分享怎么往应用助手里添加应用的知识,其中也会对应用助手怎么添加微信进行解释,如果能...
家里可以做假山养金鱼吗(假山能... 今天百科达人给各位分享家里可以做假山养金鱼吗的知识,其中也会对假山能放鱼缸里吗进行解释,如果能碰巧解...
四分五裂是什么生肖什么动物(四... 本篇文章极速百科小编给大家谈谈四分五裂是什么生肖什么动物,以及四分五裂打一生肖是什么对应的知识点,希...
一帆风顺二龙腾飞三阳开泰祝福语... 本篇文章极速百科给大家谈谈一帆风顺二龙腾飞三阳开泰祝福语,以及一帆风顺二龙腾飞三阳开泰祝福语结婚对应...
美团联名卡审核成功待激活(美团... 今天百科达人给各位分享美团联名卡审核成功待激活的知识,其中也会对美团联名卡审核未通过进行解释,如果能...